Implementando Statement e RecordSet em bash script
Publicado por Pedro Robson Leão (última atualização em 02/12/2010)
[ Hits: 4.899 ]
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 ${@};
Filtrando trabalhos de impressão...
Limitador de conexões para usuários
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
Atualizar Linux Mint 22.2 para 22.3 beta
Jogar games da Battle.net no Linux com Faugus Launcher
Como fazer a Instalação de aplicativos para acesso remoto ao Linux
Conky, alerta de temperatura alta (10)
Assisti Avatar 3: Fogo e Cinzas (3)
Duas Pasta Pessoal Aparecendo no Ubuntu 24.04.3 LTS (42)









