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 14:22 | Komunita

    Dle plánu byl vývoj Firefoxu přesunut z Mercurialu na Git. Oficiální repozitář se zdrojovými kódy je na GitHubu.

    Ladislav Hagara | Komentářů: 2
    dnes 04:33 | Bezpečnostní upozornění

    V terminálovém multiplexoru GNU Screen byly nalezeny a v upstreamu ve verzi 5.0.1 už opraveny bezpečnostních chyby CVE-2025-23395, CVE-2025-46802, CVE-2025-46803, CVE-2025-46804 a CVE-2025-46805. Podrobnosti na blogu SUSE Security Teamu.

    Ladislav Hagara | Komentářů: 31
    včera 19:33 | Bezpečnostní upozornění

    Training Solo (Paper, GitHub) je nejnovější bezpečnostní problém procesorů Intel s eIBRS a některých procesorů ARM. Intel vydal opravnou verzi 20250512 mikrokódů pro své procesory.

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

    Byla vydána nová verze 25.05.11 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Nejnovější Shotcut je již vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

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

    Svobodný elektronický platební systém GNU Taler (Wikipedie, cgit) byl vydán ve verzi 1.0. GNU Taler chrání soukromí plátců a zároveň zajišťuje, aby byl příjem viditelný pro úřady. S vydáním verze 1.0 byl systém spuštěn ve Švýcarsku.

    Ladislav Hagara | Komentářů: 10
    včera 00:55 | Pozvánky

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 209. brněnský sraz, který proběhne tento pátek 16. května od 18:00 ve studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Jelikož se Brno stalo jedním z hlavních míst, kde se vyvíjí open source knihovna OpenSSL, tentokrát se OpenAlt komunita potká s komunitou OpenSSL. V rámci srazu Anton Arapov z OpenSSL

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 00:22 | Komunita

    GNOME Foundation má nového výkonného ředitele. Po deseti měsících skončil dočasný výkonný ředitel Richard Littauer. Vedení nadace převzal Steven Deobald.

    Ladislav Hagara | Komentářů: 8
    10.5. 15:00 | Zajímavý článek

    Byl publikován přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie) za uplynulé dva měsíce. Servo zvládne už i Gmail. Zakázány jsou příspěvky generované pomocí AI.

    Ladislav Hagara | Komentářů: 29
    9.5. 17:22 | Nová verze

    Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.

    Ladislav Hagara | Komentářů: 6
    9.5. 15:22 | Komunita

    Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.

    Ladislav Hagara | Komentářů: 0
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (2%)
     (1%)
     (0%)
     (3%)
    Celkem 601 hlasů
     Komentářů: 26, poslední 8.5. 09:58
    Rozcestník

    Dotaz: MYSQL selektování údajů při změně stavu

    25.1.2009 15:16 jarda
    MYSQL selektování údajů při změně stavu
    Přečteno: 497×

    Dobrý den, dejme tomu že mám tuto tabulku

    CREATE TABLE n (
      id int(11) NOT NULL auto_increment,
      datum datetime NOT NULL,
      stav tinyint(1) NOT NULL,
      PRIMARY KEY  (id)
    ) ENGINE=MyISAM  DEFAULT CHARSET=utf8;
    
    INSERT INTO n (id, datum, stav) VALUES
    (1, '2009-01-25 13:26:56', 0),
    (2, '2009-01-25 13:27:47', 0),
    (3, '2009-01-25 13:28:23', 0),
    (4, '2009-01-25 13:28:35', 0),
    (5, '2009-01-25 13:28:46', 3),
    (6, '2009-01-25 13:29:01', 3),
    (7, '2009-01-25 13:29:10', 1),
    (8, '2009-01-25 14:48:42', 1),
    (9, '2009-01-25 14:48:48', 1),
    (10, '2009-01-25 14:48:56', 0),
    (11, '2009-01-25 14:49:02', 0),
    (12, '2009-01-25 14:49:08', 0);
    šel by udělat dotaz, který by vrátil datum kde došlo ke změně stavu? tedy řádky s id 5,7,10 popř. i s prvním a posledním řádkem 1,12.
    Dále by sem chtěl vědet jestli jde v jednom selectu nějak porovnávat aktuální řádek s dalším řádkem tedy něco ve smylu "stav != stav(dalšího řádku)"
     

    Odpovědi

    25.1.2009 17:11 Karel Borkovec | skóre: 28 | blog: HP_NX9010 | Tábor
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    To jsem zvědavý jestli takový select jde vytvořit.

    Asi bych to řešil procedurou nebo triggerem a další tabulkou.

    Přemek Vyhnal avatar 25.1.2009 17:12 Přemek Vyhnal | skóre: 24 | blog: Toto není blog! | Dobřichovice
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    kdyby tam zadne id nechybelo (byly v rade za sebou) tak neco takoveho?

    SELECT n2.id FROM n n1 JOIN n n2 ON (n2.id = n1.id + 1) WHERE n1.stav != n2.stav

    NO RAPTORS!
    Přemek Vyhnal avatar 25.1.2009 17:44 Přemek Vyhnal | skóre: 24 | blog: Toto není blog! | Dobřichovice
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    Nebo bez ohledu na id jen podle data (id muze byt libovolne) a vcetne prvniho a posledniho radku

    SELECT n2.id as id, n2.datum as datum, n2.stav as novy_stav
    FROM n n1
    RIGHT JOIN n n2 ON (
     n2.datum = (SELECT min(datum) FROM n WHERE datum > n1.datum )
    )
    WHERE n1.stav != n2.stav
    OR n2.datum = (SELECT min(datum) FROM n)
    OR n2.datum = (SELECT max(datum) FROM n)

    NO RAPTORS!
    25.1.2009 17:45 Karel Borkovec | skóre: 28 | blog: HP_NX9010 | Tábor
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    Jak píšeš, kdyby tam žádné nechybělo. Na to bych se nespoléhal....

    26.1.2009 21:06 jarda
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    No podle těch id to určitě dělat nebudu, protože nejdou po sobě, jinak to druhé řešení funguje tak jak má, ale je tam problém při větším množství záznamů,

    jenom při 200 záznamech mi to trvá nějakých 30s. A když bych měl několik tisíc záznamů, tak už je ten dotaz nepoužitelný.

    26.1.2009 21:11 Karel Borkovec | skóre: 28 | blog: HP_NX9010 | Tábor
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    Máš tam patřičné indexy?

    26.1.2009 21:46 jarda
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    Nejsou tam.

    26.1.2009 22:25 Karel Borkovec | skóre: 28 | blog: HP_NX9010 | Tábor
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    Indexy Ti značně zrychlí selecty, ale zase na úkor insertům. Pokud se do té tabulky nevkládají data po stovkách řádcích, tak se nemusíš bát.

    28.1.2009 13:17 Ivan
    Rozbalit Rozbalit vše OT: Re: MYSQL selektování údajů při změně stavu

    Sice je to OT, ale v  Oracle XE by slo by to pomoci analickych dotazu. Postgres pre taky neco takovyho ma.

     

    1.2.2009 21:46 kirpike | skóre: 8 | Plzeň
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu

    Nemohlo by (tedy v MySQL) fungovat něco jako:

    set @m=-1;select id,datum,@m:=stav from (select * from n order by datum) t where stav<>@m;

    Já vím, je to docela drsný ;-)

    Co se týká výše uvedeného řešení, tak podle mne nefunguje dobře, pokud by bylo více záznamů ve stejný čas.

    Josef Kufner avatar 2.2.2009 17:54 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: MYSQL selektování údajů při změně stavu
    Asi bych tam dal pomocný sloupec predchozi_stav, který by obsahoval předchozí stav (to co je o řádek výš). Takže select na zjištění změn by byl triviální:
    SELECT * FROM n WHERE stav != predchozi_stav
    Insert by pak musel být proveden nadvakrát:
    INSERT INTO n SET datum = NOW(), stav = $s, predchozi_stav = NULL;
     
    SET @predchozi_stav = (
       SELECT stav
       FROM n
       WHERE datum = (
          SELECT MAX(datum)
          FROM n
          WHERE datum < NOW() AND predchozi_stav IS NOT NULL
       )
    );
     
    UPDATE n
    SET predchozi_stav = @predchozi_stav
    WHERE id = LAST_INSERT_ID();
    Samotné zjišťování předchozího stavu určitě půjde výrazně zjednodušit. Navíc pokud si ho vyplňující program může mezi jednotlivými inserty pamatovat, nebude to znamenat prakticky žádnou režii navíc (a stačí jeden insert).
    Hello world ! Segmentation fault (core dumped)

    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.