Portál AbcLinuxu, 20. července 2025 16:51
mesic den cas ip
mesic den cas ip
mesic den cas ip
mesic den cas ip
Potrebuju prevest text.log soubor do mysql databaze a z kazdeho radku vytahuju mesic den cas ip , problem je v tom ze nevim jak prevest postupne vsechny radky do mysql tabulky
mesic=`cat text.log | awk '{print $1}'`
den=`cat textlog | awk '{print $2}'`
cas=`cat text.log | awk '{print $3}'`
ipadresa=`cat text.log | awk '{print $4}'`
mysql -N -D databaze -u user -pheslo -e "INSERT INTO tabulka ( mesic , den , cas , ipadresa ) VALUES ('$mesic','$den','$cas','$ipadresa')" databaze
jen vim ze by bylo dobre je zpracovat v cyklech ?
nejako takto:
mysql -N -D databaze -u user -pheslo < `awk '{printf("INSERT INTO tabulka (mesic, den, cas, ipadresa) VALUES ('"'"%s"'"', '"'"%s"'"', '"'"%s"'"', '"'"%s"'"')\n", $1, $2, $3, $4)}' text.log`
dobry den
Urcite jde napsat:
awk '// {print "mysql -N -D databaze -u user -pheslo -e \"INSERT INTO tabulka ( mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27)\" databaze"}' < text.log | sh
Tohle bude jakztakz fungovat, pokud tam nebude moc radku. Jinak je lepsi pouzit konstrukci LOAD DATA INFILE.
marek
anebo o neco elegantneji (nemam nikde mysql - nevim, zda se mu nemusi rict, at cte z stdin):
awk '// {print "INSERT INTO tabulka ( mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27);" ' < text.log | mysql -N -D databaze -u user -pheslo databaze
marek
funguje perfektne jen jsem z toho trochu rozpacity ze pouzivam neco aniz bych vedel jak to funguje , stacilo by me jen trosku nakopnout at v tom moc nelitam , jeste jednou dekuju
Dobry den.
Predpokladam ze rozumite vasemu zapisu
cat text.log | awk '{print $1}'
to jde elegantneji prepsat jako
awk '{print $1}' < text.log
tim se odstrani zbytecne volani cat.
Pokud pustite
awk '// {print "mysql -N -D databaze -u user -pheslo -e \"INSERT INTO tabulka ( mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27)\" databaze"}' < text.log
vypise Vam to akorat preparsovany text (uplne stejne jako ten Vas prikaz), ktery je vlastne to, co byste psal na klavesnici, kdybyste to tam rucne cpal.
Takze se to akorat posle rourou na stdin shellu. Neni to ale idealni reseni, protoze se pro kazdy radek znovu vola mysql.
Daleko lepsi je mysql pustit prave jednou a na stdin mu poslat vsechny radky.
takze, kdyz pustite
awk '// {print "INSERT INTO tabulka ( mesic , den , cas , ipadresa ) VALUES (\x27" $1 "\x27,\x27" $2 "\x27,\x27" $3 "\x27,\x27" $4 "\x27);" ' < text.log
vypise Vam to akorat preparsovany text, ktery je vlastne to, co byste psal na klavesnici, po spusteni mysql v interaktivnim modu.
To \x27 je zapis uvozovek pro awk.
marek
Tiskni
Sdílej:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.