Implementando Statement e RecordSet em bash script
Publicado por Pedro Robson Leão (última atualização em 02/12/2010)
[ Hits: 4.896 ]
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 ${@};
POSTFIX AUTOMÁTICO COM MYSQL E IPTABLES - DESBLOQUEAR IP
Front-end para backup em CDRW e DVDRW
Script para montagem de compartilhamento SAMBA (Gentoo)
Claro 3g Sony Ericsson md300 script conexao REVISAO 2
Select tempfiles - Database Oracle
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
Jogar games da Battle.net no Linux com Faugus Launcher
Como fazer a Instalação de aplicativos para acesso remoto ao Linux
Como fazer a instalação do Samba
Como fazer a conversão binária e aplicar as restrições no Linux
Duas Pasta Pessoal Aparecendo no Ubuntu 24.04.3 LTS (19)
Formas seguras de instalar Debian Sid (13)
Malware encontrado em extensões do Firefox. (0)
Fiz uma pergunta no fórum mas não consigo localizar [RESOLVIDO] (21)









