Implementando Statement e RecordSet em bash script
Publicado por Pedro Robson Leão (última atualização em 02/12/2010)
[ Hits: 4.700 ]
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 ${@};
Criando um Backup .ISO do seu CD.
Ajuste Dinâmico do Governador de CPU no Linux
Script - Realizando relatório do servidor
Limpar o lixo das caixas de e-mail dos usuários que usam Maildir...
Resolver problemas de Internet
Como compartilhar a tela do Ubuntu com uma Smart TV (LG, Samsung, etc.)
Descritores de Arquivos e Swappiness
Solução rápida para o problema do Network Manager conectar mas não navegar
Como instalar no Linux Jogos da Steam só para Windows
Instalando o Team Viewer no Debian Trixie - problema no Policykit
Erro GLPI 10.0.0.18 - Ticket (1)
Montando e usando iso de um sistema dentro do outro (6)