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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 9
dnes 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 4
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 10
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
2.12. 22:44 | Komunita

Joinup informuje, že Mnichov používá open source groupware Kolab. V srpnu byl dokončen dvouletý přechod na toto řešení. V provozu je asi 60 000 poštovních schránek. Nejenom Kolabu se věnoval Georg Greve ve své přednášce Open Source: the future for the European institutions (SlideShare) na konferenci DIGITEC 2016, jež proběhla v úterý 29. listopadu v Bruselu. Videozáznam přednášek z hlavního sálu je ke zhlédnutí na Livestreamu.

Ladislav Hagara | Komentářů: 25
2.12. 15:30 | Zajímavý projekt

Společnost Jolla oznámila v příspěvku Case study: Sailfish Watch na svém blogu, že naportovala Sailfish OS na chytré hodinky. Využila a inspirovala se otevřeným operačním systémem pro chytré hodinky AsteroidOS. Použita je knihovna libhybris. Ukázka ovládání hodinek na YouTube.

Ladislav Hagara | Komentářů: 8
2.12. 14:15 | Nová verze

Byla vydána verze 7.1.0 skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Jedná se o první stabilní verzi nejnovější větvě 7.1. Přehled novinek v dokumentaci. Podrobnosti v ChangeLogu. K dispozici je také příručka pro přechod z PHP 7.0.x na PHP 7.1.x.

Ladislav Hagara | Komentářů: 4
2.12. 12:55 | Nová verze

Google Chrome 55 byl prohlášen za stabilní. Nejnovější stabilní verze 55.0.2883.75 tohoto webového prohlížeče přináší řadu oprav a vylepšení (YouTube). Opraveno bylo také 36 bezpečnostních chyb. Mariusz Mlynski si například vydělal 22 500 dolarů za 3 nahlášené chyby (Universal XSS in Blink).

Ladislav Hagara | Komentářů: 4
2.12. 11:55 | Pozvánky

Máte rádi svobodný software a hardware nebo se o nich chcete něco dozvědět? Přijďte na 135. sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.

xkucf03 | Komentářů: 1
2.12. 00:10 | Nová verze

Byla vydána verze 3.2 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata. Z novinek lze zmínit například podporu protokolů DNP3 a CIP/ENIP, vylepšenou podporu TLS a samozřejmě také aktualizovanou dokumentaci.

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (7%)
 (5%)
 (3%)
Celkem 772 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

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: 344×
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: 66 | 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: 66 | 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: 66 | 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.