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íží...
včera 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
včera 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

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

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 1
6.12. 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 25
6.12. 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 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ářů: 50
5.12. 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ářů: 10
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ářů: 17
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
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%)
 (8%)
 (5%)
 (3%)
Celkem 785 hlasů
 Komentářů: 50, poslední 29.11. 15:50
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: 462×

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.