abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 00:22 | Nová verze

    Byla vydána nová stabilní verze 25.05 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Warbler. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.

    Ladislav Hagara | Komentářů: 0
    včera 18:11 | Nová verze

    Multiplatformní open source spouštěč her Heroic Games Launcher byl vydán v nové stabilní verzi 2.17.0 Franky (Mastodon, 𝕏). Přehled novinek na GitHubu. Instalovat lze také z Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 18:00 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 26 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 14:55 | IT novinky

    Klávesnice IBM Enhanced Keyboard, známá také jako Model M, byla poprvé představena v roce 1985, tzn. před 40 lety, s počítači IBM 7531/7532 Industrial Computer a 3161/3163 ASCII Display Station. Výročí připomíná článek na zevrubném sběratelském webu Admiral Shark's Keyboards. Rozložení kláves IBM Enhanced Keyboard se stalo průmyslovým standardem.

    Fluttershy, yay! | Komentářů: 4
    včera 12:00 | Nová verze

    Vyšlo Pharo 13 s vylepšenou podporou HiDPI či objektovým Transcriptem. Pharo je programovací jazyk a vývojové prostředí s řadou pokročilých vlastností.

    Pavel Křivánek | Komentářů: 1
    včera 04:00 | IT novinky

    Java má dnes 30. narozeniny. Veřejnosti byla představena 23. května 1995.

    Ladislav Hagara | Komentářů: 6
    22.5. 21:55 | IT novinky

    1. července Mozilla vypne službu Fakespot pro detekci podvodných recenzí v internetových obchodech. Mozilla koupila Fakespot v květnu 2023.

    Ladislav Hagara | Komentářů: 1
    22.5. 21:33 | IT novinky

    8. července Mozilla vypne službu Pocket (Wikipedie) pro ukládání článků z webu na později. Do 8. října si uživatelé mohou vyexportovat data. Mozilla koupila Pocket v únoru 2017. Několik měsíců byl Pocket integrovanou součástí Firefoxu.

    Ladislav Hagara | Komentářů: 5
    22.5. 13:22 | Upozornění

    Turris OS má aktuálně problém s aktualizací související s ukončením podpory protokolu OCSP u certifikační autority Let's Encrypt.

    Ladislav Hagara | Komentářů: 4
    22.5. 04:00 | Zajímavý článek

    Nevidomý uživatel Linuxu v blogu upozornil na tristní stav přístupnosti na linuxovém desktopu (část první, druhá, závěr), přičemž stížnosti jsou podobné jako v roce 2022. Vyvolal bouřlivou odezvu. Následně např. Georges Stavracas shrnul situaci v GNOME. Debata o jiném aspektu přístupnosti, emulaci vstupu pod Waylandem, také proběhla na Redditu.

    Fluttershy, yay! | Komentářů: 8
    Jaký je váš oblíbený skriptovací jazyk?
     (57%)
     (28%)
     (7%)
     (3%)
     (0%)
     (0%)
     (6%)
    Celkem 90 hlasů
     Komentářů: 6, poslední 22.5. 14:43
    Rozcestník

    Dotaz: Bash - přístup k mysql

    1.2.2007 22:26 Zmije
    Bash - přístup k mysql
    Přečteno: 350×
    Hezký den. Na routeru se momentálně snažím vytvořit skript v bashi, který každý den zkontroluje datum a pokud je nový měsíc, tak ho aktualizuje v databáze mysql. Tabulka měsíce je jednoduchá id,mesic(varchar) Snažím se využít této konstrukce
    mysql -N -D webconf -u root -e 'update mesice set mesi='$mesic' where id=2'
    našel sem ji tu v některé starší diskusi. Dostanu tuhle hlasku
    line 14: [: mesic: integer expression expected
    pokud místo proměnné použiju přímo hodnotu, tak to funguje bez problémů. Jakým způsem by se dalo pracovat s mysql v bashi?

    Odpovědi

    Josef Kufner avatar 1.2.2007 23:04 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    Bash se pokouší interpretovat obsah $mesi. Použij uvozovky:
    mysql -N -D webconf -u root -e "update mesice set mesi=$mesic where id=2"
    Hello world ! Segmentation fault (core dumped)
    Fuky avatar 1.2.2007 23:20 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    mysql -N -D webconf -u root -e "update mesice set mesi='$mesic' where id=2" ;-)
    1.2.2007 23:34 wosambo | skóre: 5
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    zprvu me tohle napadlo taky, ale pak jsem to odzkousel a ejhle, v mysql muzu varchar i text updatovat integerem, spis, jak jsem napsal nize, by autor otazky mel uvest vice ze sveho skriptu.
    1.2.2007 23:37 wosambo | skóre: 5
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    aha, ze by ten radek 14 byl ten vyraz s mysql uzavreny do hranatych zavorek? pak uz mlcim ;)
    1.2.2007 23:40 wosambo | skóre: 5
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    aha. ale to vlastne uz teprv nejde, to by chudak [ nevedel, ci je. primlouvam se znovu za vetsi poodhaleni tajemneho radku 14, co ze je to tomu prikazu [ predhozeno.
    1.2.2007 23:32 wosambo | skóre: 5
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    Mam takovej dojem, ze problem nebude v uvedenem radku s prikazem mysql, ale v pouziti prikazu [ (ekvivalent prikazu test), kde to pozaduje integer a ne to, co tam misto integeru je. Ale to by chtelo uvest bud cely ten skript a nebo aspon ten radek 14.
    9.2.2007 00:06 Zmije
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    Omlovám se všem za zbytečný dotaz, problém byl opravdu mimo řádek se čtením z DB. Totiž DB používám delší dobu, takže sem ji musel trochu poupravit nyní vypadá takto: id(auto increment, primary key..) mesic (varchar) mesicnum (varchar). Do mesicnum sem uložil listopad místo 2005/11 a o pár řádků dál sem to chtěl porovnávat jako číslo a vtom byl ten problém. Posílám vám alespoň hotový skript, múžete si rejpnou (vím že je to paskvil).
    #! /bin/bash
    #spousteno cronem kazde 3 hodiny 
    echo "######################### SYNCH - START ###########################################"
    ntpdate ntp.cesnet.cz
    
    ##############################Vlozeni noveho mesice#####################################
    #zjisteni aktualniho(posledniho-Last) mesice LMounth
    LMounth=$(date +%m)
    LMounth=${LMounth#0}
    
    #osetreni pokud mesic zacina 0 ;je potreba regulerni cislo 
    LMounth=${LMounth#0}
    
    #zjisteni aktualniho(posledniho-Last) roku LYear
    LYear=$(date +%Y)
    LDate=$LYear$LMounth
    
    #z DB vyber nejvyssi datum a porovnej jestli neni mensi nez aktualni, v pripade ze je pridej mesic
    zaznam=$(mysql -N -D webconf -u root -e "select mesice.id,mesice.mesicnum from mesice
     join (select max(mesice.mesicnum)as mesicmax from mesice)as nejvyssi on mesice.mesicnum=mesicmax")
    mesicid=${zaznam%%$'\t'*}
    zaznam2=${zaznam#$mesicid}
    rok=${zaznam2%%/*}
    rok=${rok#*$'\t'}
    
    mesic=${zaznam2#*$rok/}
    Mounth=${mesic#0}
    Year=$rok
    
    while [ "$Year$Mounth" != "$LYear$LMounth" ]; do
    Mounth=$((Mounth + 1))
    if [ "$Mounth" -gt 12 ]; then
      Year=$((Year+1))
      Mounth=1
    fi
    mesicid=$((mesicid+1))
    
    #slovni zapis mesice
    ##definice pole SMesic
    SMesic=( nultý leden únor březen duben květen červen červenec srpen září říjen listopad prosinec)
    
    mesicnum=$(echo $Year'/'$Mounth)
    if [ "${#Mounth}" = 1 ];then
    mesicnum=$(echo $Year'/0'$Mounth)
    fi
    
    # mysql -N -D webconf -u root -e "update mesice set mesic='${SMesic[$Mounth]} $Year', mesicnum='$mesicnum' where id='$mesicid'"
    mysql -N -D webconf -u root -e "insert mesice (mesic,mesicnum) values ('${SMesic[$Mounth]} $Year','$mesicnum')"
    
    done
    echo "######################### SYNCH - HOTOVO ##########################################"
    9.2.2007 08:54 Ash
    Rozbalit Rozbalit vše Re: Bash - přístup k mysql
    To jste sem neměl dávat, teď se lidi budou ptát kdo vás nutí k takovýmhle ..vylomeninám :)

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.