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 12:00 | Nová verze

Po cca 3 týdnech od vydání Linux Mintu 18.3 s kódovým jménem Sylvia a prostředími MATE a Cinnamon byla oznámena také vydání s prostředími KDE a Xfce. Podrobnosti v poznámkách k vydání (KDE, Xfce) a v přehledech novinek s náhledy (KDE, Xfce). Linux Mint 18.3 je podporován do roku 2021.

Ladislav Hagara | Komentářů: 2
včera 12:55 | Nová verze

Byla vydána verze 17.12.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi. Aplikace, které nebyly dosud portovány na KDE Frameworks 5, byly z KDE Aplikací odstraněny.

Ladislav Hagara | Komentářů: 38
včera 03:00 | Komunita

Na Humble Bundle lze získat počítačovou hru Company of Heroes 2 (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 0
včera 02:00 | Zajímavý software

Christian Kellner představil na svém blogu projekt Bolt řešící bezpečnost rozhraní Thunderbolt 3 na Linuxu. Pomocí příkazu boltctl nebo rozšíření GNOME Shellu lze komunikovat s démonem boltd a například zakázat neznámá zařízení a předejít tak útokům typu Thunderstrike nebo DMA.

Ladislav Hagara | Komentářů: 8
včera 01:00 | Nová verze

Po půl roce vývoje od vydání verze 11.0 byla vydána verze 11.1 svobodného softwaru pro vytváření datových úložišť na síti FreeNAS (Wikipedie). Nejnovější FreeNAS je postaven na FreeBSD 11.1. Přehled novinek v příspěvku na blogu. Zdůraznit lze zvýšení výkonu OpenZFS, počáteční podporu Dockeru nebo synchronizaci s cloudovými službami Amazon S3 (Simple Storage Services), Backblaze B2 Cloud, Google Cloud a Microsoft Azure

Ladislav Hagara | Komentářů: 0
14.12. 23:55 | Nová verze

Po dvou měsících vývoje od vydání verze 235 oznámil Lennart Poettering vydání verze 236 správce systému a služeb systemd (GitHub, NEWS).

Ladislav Hagara | Komentářů: 10
14.12. 20:00 | Nová verze Ladislav Hagara | Komentářů: 0
14.12. 19:33 | Pozvánky

Pražská Fedora 27 Release Party, oslava nedávného vydání Fedory 27, se uskuteční 19. prosince od 19:00 v prostorách společnosti Etnetera (Jankovcova 1037/49). Na programu budou přednášky o novinkách, diskuse, neřízený networking atd.

Ladislav Hagara | Komentářů: 0
14.12. 18:11 | Nová verze

Byla vydána verze 2.11.0 QEMU (Wikipedie). Přispělo 165 vývojářů. Provedeno bylo více než 2 000 commitů. Přehled úprav a nových vlastností v seznamu změn.

Ladislav Hagara | Komentářů: 0
14.12. 17:44 | Komunita

Canonical oznámil dostupnost kryptografických balíčků s certifikací FIPS 140-2 úrovně 1 pro Ubuntu 16.04 LTS pro předplatitele podpory Ubuntu Advantage Advanced. Certifikace FIPS (Federal Information Processing Standards) jsou vyžadovány (nejenom) vládními institucemi USA.

Ladislav Hagara | Komentářů: 3
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (8%)
 (0%)
 (1%)
 (1%)
 (76%)
 (14%)
Celkem 1002 hlasů
 Komentářů: 45, poslední 1.12. 19:00
    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: 348×
    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: 67 | 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: 67 | 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: 67 | 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.