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 11:00 | Komunita

Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už zítra 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.

xkucf03 | Komentářů: 0
včera 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

Ladislav Hagara | Komentářů: 4
včera 16:44 | Nová verze

Byla vydána verze 2.0.0 knihovny pro vykreslování grafů v programovacím jazyce Python Matplotlib (Wikipedie, GitHub). Přehled novinek a galerie grafů na stránkách projektu.

Ladislav Hagara | Komentářů: 0
včera 15:33 | Komunita

V australském Hobartu probíhá tento týden konference linux.conf.au 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online.

Ladislav Hagara | Komentářů: 0
včera 10:20 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje bitmapovým (rastrovým) grafickým editorům ve Fedoře. V prvním dílu se věnuje editorům MyPaint, MtPaint, Pinta, XPaint, Krita a GIMP. V pokračování pak editorům GNU Paint (gpaint), GrafX2, KolourPaint, KIconEdit a Tux Paint.

Ladislav Hagara | Komentářů: 1
16.1. 17:11 | Komunita

Byl proveden bezpečnostní audit svobodného IMAP a POP3 serveru Dovecot (Wikipedie). Audit byl zaplacen z programu Mozilla Secure Open Source a provedla jej společnost Cure53. Společnost Cure53 byla velice spokojena s kvalitou zdrojových kódu. V závěrečné zprávě (pdf) jsou zmíněny pouze 3 drobné a v upstreamu již opravené bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
16.1. 15:30 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi Compute Module 3 (CM3 a CM3L), tj. zmenšené Raspberry Pi vhodné nejenom pro průmyslové využití. Jedná se o nástupce Raspberry Pi Compute Module (CM1) představeného v dubnu 2014. Nový CM3 vychází z Raspberry Pi 3 a má tedy dvakrát více paměti a desetkrát větší výkon než CM1. Verze CM3L (Lite) je dodávána bez 4 GB eMMC flash paměti. Uživatel si může připojit svou vlastní. Představena byla

… více »
Ladislav Hagara | Komentářů: 2
16.1. 01:23 | Nová verze

Oficiálně bylo oznámeno vydání verze 3.0 multiplatformního balíku svobodných kancelářských a grafických aplikací Calligra (Wikipedie). Větev 3 je postavena na KDE Frameworks 5 a Qt 5. Krita se osamostatnila. Z balíku byly dále odstraněny aplikace Author, Brainstorm, Flow a Stage. U Flow a Stage se předpokládá jejich návrat v některé z budoucích verzí Calligry.

Ladislav Hagara | Komentářů: 7
15.1. 15:25 | Nová verze

Bylo oznámeno vydání první RC (release candidate) verze instalátoru pro Debian 9 s kódovým názvem Stretch. Odloženo bylo sloučení /usr jako výchozí nastavení v debootstrap. Vydán byl také Debian 8.7, tj. sedmá opravná verze Debianu 8 s kódovým názvem Jessie.

Ladislav Hagara | Komentářů: 6
15.1. 13:37 | Zajímavý projekt

1. ledna byl představen projekt Liri (GitHub). Jedná se o spojení projektů Hawaii, Papyros a původního projektu Liri s cílem vyvíjet operační systém (linuxovou distribuci) a aplikace s moderním designem a funkcemi. Včera byl představen Fluid 0.9.0 a také Vibe 0.9.0. Jedná se o toolkit a knihovnu pro vývoj multiplatformních a responzivních aplikací podporující Material Design (Wikipedie) a volitelně také Microsoft Design Language (designový jazyk Microsoft) [reddit].

Ladislav Hagara | Komentářů: 9
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 309 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

    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: 463×

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