Implementando Statement e RecordSet em bash script
Publicado por Pedro Robson Leão (última atualização em 02/12/2010)
[ Hits: 4.617 ]
Já publiquei um script similar em: http://www.vivaolinux.com.br/script/MySQL-bash-script
Porém refactory é sempre bom para melhorar nossos códigos.
Bem, o exemplo a seguir é mais enxuto e funcional, mesmo tratando-se de um código conceitual explorando todo o poder do bash script.
#!/bin/bash DB_USER='user'; DB_PWD='password'; DB_HOST='localhost'; DB="mysql" DB_CLIENT="/usr/bin/mysql -u${DB_USER} -p${DB_PWD} -h${DB_HOST} $( [ ! -z "${DB}" ] && echo ${DB} || echo "" ) -e "; function statement() { local ifs=${IFS}; local line=; local ct=0; local err=$(mktemp); RS=(); IFS="|"; local query=" ${DB_CLIENT} \"${@}\" 2>${err}"; while read line ; do if [ ${ct} -eq 0 ] ; then FIELD=( ${line} ); else _RS=( ${line} ); local sz=${#FIELD[@]}; local i=; for ((i=0;i<sz;i++)) ; do local row=$((ct-1)); local field="${FIELD[$i]}"; local value="${_RS[$i]}"; field="${field//[- ]/_}"; eval "${field}[$row]='${value}'"; RS[${row}]="${line}"; done fi ct=$((ct+1)); done < <( eval ${query} | sed 's/ / /g' | tr ' ' '|' ); IFS="${ifs}"; DBERRMSG=$( cat ${err} && rm -f ${err} ); test -z "${DBERRMSG}"; } function main() { statement "SELECT Host,User FROM user" && { local rs=${#RS[@]}; local i=; for ((i=0;i<rs;i++)) { printf "Line: %-20.20s\nHost: %-20.20s\nUser: %-20.20s\n\n" \ ${i} "${Host[$i]}" "${User[$i]}"; } } || { echo ">>> ${DBERRMSG}"; } } main ${@};
conssh.sh - Frontend para SSH via proxy HTTP
Instalador .tar.bz2 com menu gráfico Zenity
Aplicando layer7 sem digitar uma linha de código sequer
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Meu Fork do Plugin de Integração do CVS para o KDevelop
Compartilhando a tela do Computador no Celular via Deskreen
Como Configurar um Túnel SSH Reverso para Acessar Sua Máquina Local a Partir de uma Máquina Remota
Configuração para desligamento automatizado de Computadores em um Ambiente Comercial
Compartilhamento de Rede com samba em modo Público/Anônimo de forma simples, rápido e fácil
Cups: Mapear/listar todas as impressoras de outro Servidor CUPS de forma rápida e fácil
Criando uma VPC na AWS via CLI
De volta para o futuro - ou melhor, para o presente (24)
Comandos no NixOS não funcionam (0)
Plasma 6 com partes em inglês (0)