Implementando Statement e RecordSet em bash script
Publicado por Pedro Robson Leão (última atualização em 02/12/2010)
[ Hits: 4.950 ]
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 ${@};
Monitoramento de usuário via screenshots
Adicionar usuarios em lote com senha padrao
Script para Ler código de barras serial e jogar no buffer do teclado
A combinação de WMs com compositores feitos por fora
Audacious, VLC e QMMP - que saudades do XMMS
SUNO OpenSource: Crie um servidor de gerador de música com IA
Instalação Completa e Configuração Básica do Void Linux
A Fundação da Confiança Digital: A Importância Estratégica de uma PKI CA na Segurança de Dados
Script para configurar o DOOM Retro no Linux
Script para organizar janelas em cascata no KDE Plasma 6 (Wayland)
Módulo de segurança warsaw CEF (1)
Mudança de Source do Xboxdrv (3)









