abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 17:11 | Nová verze

    Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.

    Ladislav Hagara | Komentářů: 3
    včera 13:33 | Nová verze

    Vyšlo Pharo 12.0, programovací jazyk a vývojové prostředí s řadou pokročilých vlastností. Krom tradiční nadílky oprav přináší nový systém správy ladících bodů, nový způsob definice tříd, prostor pro objekty, které nemusí procházet GC a mnoho dalšího.

    Pavel Křivánek | Komentářů: 7
    včera 04:55 | Zajímavý software

    Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.

    Ladislav Hagara | Komentářů: 35
    25.4. 17:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.

    Ladislav Hagara | Komentářů: 13
    25.4. 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

    Ladislav Hagara | Komentářů: 3
    25.4. 13:22 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

    Ladislav Hagara | Komentářů: 0
    25.4. 12:44 | Nová verze

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

    Ladislav Hagara | Komentářů: 0
    25.4. 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

    Ladislav Hagara | Komentářů: 0
    25.4. 04:22 | Nová verze

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    25.4. 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (74%)
     (8%)
     (2%)
     (16%)
    Celkem 820 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: sql delete statement , jak zjistit ktera podminka neni splnena

    29.12.2010 19:17 jk
    sql delete statement , jak zjistit ktera podminka neni splnena
    Přečteno: 374×
    mam sql prikaz

    delete from my_table where ID='12345' and TIMESTAMP='98765432'

    Jde zjistit, ktera podminka nebyla splnena:

    - ID 12345 neexistuje

    - TIMESTAMP je rozdilny

    Prostredi mysql, sqlite, pgsql C.

    Je eventuelne nutne prikaz nejak rozlozit do dvou?

    Řešení dotazu:


    Odpovědi

    29.12.2010 19:35 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: sql delete statement , jak zjistit ktera podminka neni splnena
    SELECT * FROM my_table WHERE ID='12345'
    SELECT * FROM my_table WHERE TIMESTAMP='98765432'
    
    Doporučoval bych ale nastudovat si základy SQL, bez toho nemá smysl se pokoušet vytvářet příkazy metodou pokus–omyl.

    Mimochodem, ID je obyčejně unikátní (a v databázi bývá nastavena kontrola unikátnosti), takže pak je ta druhá část podmínky zbytečná.
    29.12.2010 20:15 jk
    Rozbalit Rozbalit vše Re: sql delete statement , jak zjistit ktera podminka neni splnena
    hm, i kdyz je dotaz oznacen jako vyrizen (tedy alespon tak rozumim tomu hacku) , tak jsem nyni trochu zmaten a rad bych se proto zeptal, zda je muj vyse uvedeny sql-prikaz spravny, jestlize chci:

    z tabulky my_table smazat radku, ktera je jednoznacne identifikovana pomoci sloupce ID s hodnotou '12345' a smazani se ma provest ale pouze v tom pripade, ze hodnota sloupce TIMESTAMP je rovna '98765432'. Jestlize prikaz neni spravny , pak bych prosil o korekturu.

    Dekuji.
    29.12.2010 20:54 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: sql delete statement , jak zjistit ktera podminka neni splnena
    Ano, ten příkaz dělá to, co popisujete.
    30.12.2010 14:47 jk
    Rozbalit Rozbalit vše Re: sql delete statement , jak zjistit ktera podminka neni splnena
    ok, takze ted k tomu problemu. Uzivatel si nacetl udaje z radky a (po nejake dobe) se rozhodl ji smazat. Preda databazi tedy ID a TIMESTAMP, jak si je nacetl.

    Jestlize napr. odsadim takovy prikaz v sqlite, tak vysledek je, ze se prikaz provedl bez chyby (coz znaci , ze bylo dost pameti, jadro melo dost zdroju apod), ale jeste nevim, zda se neco smazalo ci ne. Nyni se mohu v sqlite zeptat, kolik 'zmen' nastalo 'v posledni chvili'.

    Jestlize 1 zmena, tak doslo ke smazani, kdyz 0, tak se nic nesmazalo. Ale ja v te chvili nevim, jestli se to nesmazalo, protoze ta radka uz vubec neexsitovala (mezitim ji nekdo smazal) a nebo jestli ji nekdo zmenil.

    Rad bych nyni vedel, jak se to bezne resi. Dodavaji 'lepsi' databaze udaj, zda bylo neco smazano hned a je mozno se nejak dovedet, ktera z tech WHERE klausuli byla pricinou toho 'nesmazani'?
    30.12.2010 15:03 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: sql delete statement , jak zjistit ktera podminka neni splnena
    Databáze běžně vrací počet „dotčených“ záznamů, tj. v případě mazání počet smazaných záznamů. Určitě to takhle dělá PostgreSQL a H2, předpokládám že i MySQL, Oracle a další.
    je mozno se nejak dovedet, ktera z tech WHERE klausuli byla pricinou toho 'nesmazani'
    WHERE je logická podmínka – testuje se každý záznam, pokud je podmínka vyhodnocena jako pravdivá, záznam se smaže, pokud je nepravdivá, záznam se nechá být. Pokud byste chtěl zjistit, které části podmínky nějaký konkrétní záznam nevyhovuje, musíte nejdřív nějak dokázat ten záznam jednoznačně identifikovat. K tomu by ale nejspíš sloužilo to ID, a pokud pak chcete záznam s daným ID smazat, prostě dejte do podmínky jenom to ID. Pokud jej chcete smazat jedině v případě, kdy má zároveň konkrétní TIMESTAMP, použijte tu vaši podmínku. Pokud chcete uživatele informovat, že nedošlo ke smazání, protože se mezi tím TIMETSTAMP změnil, udělejte pod smazání SELECT na dané ID – pokud něco najdete, víte, že se záznam nesmazal a že jej tedy někdo musel změnit. Všechno je to ale takové na vodě, protože se tam nepoužívá zamykání, takže může kdykoli dojít ke změně – ale předpokládám, že zamykání nechcete používat schválně.
    31.12.2010 15:24 jk
    Rozbalit Rozbalit vše Re: sql delete statement , jak zjistit ktera podminka neni splnena
    diky

    To s tim zamykanim mate pravdu, ale i to 'na vode' myslim bude dostacovat.

    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.