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

Pocket (dříve Read It Later) (Wikipedie) je oblíbená služba umožňující uložit si článek z webu na později. V červnu 2015 s vydáním Firefoxu 38.0.5 se do té doby doplněk Pocket stal integrovanou součásti Firefoxu, a to i přes odpor celé řady uživatelů tohoto webového prohlížeče. Mozilla po měsících ustoupila a z integrované součásti se stal opět doplněk. Včera bylo oznámeno, že Mozilla službu Pocket kupila (Mozilla Blog, Pocket Blog).

Ladislav Hagara | Komentářů: 0
včera 23:55 | Pozvánky

Tentokrát jsme si pro vás připravili neobvyklou akci. Ve středu 1. 3. v 17:30 nás přivítá sdružení CZ.NIC ve svých prostorách v Milešovské ulici číslo 5 na Praze 3, kde si pro nás připravili krátkou prezentaci jejich činnosti. Následně navštívíme jejich datacentrum pod Žižkovskou věží. Provedou nás prostory, které jsou běžnému smrtelníkovi nedostupné!

… více »
xkucf03 | Komentářů: 0
včera 18:30 | Komunita

Jednodeskový počítač Raspberry Pi slaví již 5 let. Prodej byl spuštěn 29. února 2012. O víkendu proběhne v Cambridgi velká narozeninová party. Na YouTube bylo při této příležitosti zveřejněno video představující zajímavé projekty postavené na Raspberry Pi.

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

Byla vydána verze 2017.1.1 svobodného multiplatformního leteckého simulátoru FlightGear. Kódový název a výchozí letiště této verze je Bergen. Přehled novinek v Changelogu.

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

Mozilla.cz informuje o dvou nových experimentálních funkcích v programu Firefox Test Pilot (zprávička). Snooze Tabs slouží k odkládání panelů na později. Pokud vám někdo pošle odkaz, ale vy nemáte čas si stránku hned přečíst, můžete si naplánovat otevření panelu na později. Stačí kliknout na tlačítko a vybrat, kdy chcete panel otevřít. Firefox panel schová a ve vybraný čas znovu otevře. Pulse umožňuje ohodnotit, jak dobře stránka funguje, např. jak rychle se ve Firefoxu načetla. Podle nasbíraných hodnocení pak bude Mozilla prohlížeč ladit.

Ladislav Hagara | Komentářů: 7
včera 02:00 | IT novinky

V Barceloně probíhá veletrh Mobile World Congress 2017. Nokia na něm například představila (360° video na YouTube) novou Nokii 3310 (YouTube). BlackBerry představilo BlackBerry KEYone (YouTube) s QWERTY klávesnicí. LG představilo LG G6 (YouTube). Huawei HUAWEI P10 a P10 Plus. Samsung představil tablet Galaxy Tab S3.

Ladislav Hagara | Komentářů: 1
26.2. 14:00 | Nová verze

Komunita kolem Linuxu From Scratch (LFS) vydala Linux Linux From Scratch 8.0 a Linux From Scratch 8.0 se systemd. Nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů přichází především s Glibc 2.25 a GCC 6.3.0. Současně bylo oznámeno vydání verze 8.0 knih Beyond Linux From Scratch (BLFS) a Beyond Linux From Scratch se systemd.

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

Byla vydána verze 0.10.0 webového prohlížeče qutebrowser (Wikipedie). Přehled novinek v příspěvku na blogu. Vývojáři qutebrowseru kladou důraz na ovladatelnost pomocí klávesnice a minimální GUI. Inspirovali se prohlížečem dwb a rozšířeními pro Firefox Vimperator a Pentadactyl. Prohlížeč qutebrowser je naprogramován v Pythonu a využívá PyQt5. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GNU GPL 3.

Ladislav Hagara | Komentářů: 34
25.2. 16:22 | Nová verze

Po pěti měsících od vydání Waylandu a Westonu 1.12.0 oznámil Bryce Harrington (Samsung) vydání Waylandu 1.13.0 a Westonu 2.0.0.

Ladislav Hagara | Komentářů: 7
24.2. 13:37 | Bezpečnostní upozornění

Společnost Cloudflare (Wikipedie) na svém blogu potvrdila bezpečnostní problém s její službou. V požadovaných odpovědích od reverzní proxy byla odesílána také data z neinicializované paměti. Útočník tak mohl získat cookies, autentizační tokeny, data posílaná přes HTTP POST a další citlivé informace. Jednalo se o chybu v parsování HTML. Zneužitelná byla od 22. září 2016 do 18. února 2017. Seznam webů, kterých se bezpečnostní problém potenciálně týká na GitHubu.

Ladislav Hagara | Komentářů: 1
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (13%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 728 hlasů
 Komentářů: 69, poslední dnes 01:02
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: SELECT tak aby pozadovane ID bolo v strede

    23.6.2009 08:53 Jano33
    SELECT tak aby pozadovane ID bolo v strede
    Přečteno: 448×

    Zdravim,

    potrebujem spravit taky selekct aby moje pozadovane ID bolo v strede. Priklad.

    [id-2, id-1, id0, id1, id2]

     

    kde ID0 je moje pozadovane. Da sa spravit taky selekt aby jednoducho zobral napr. 3 predchadzajuce 3 nasledujuce zaznamy?

     

    Vdaka 

    Odpovědi

    23.6.2009 09:17 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    SELECT ... WHERE id BETWEEN X - 3 AND X + 3 ORDER BY id?
    msk avatar 23.6.2009 09:19 msk | skóre: 27 | blog: msk
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    ID je integer primary key? Ak ano, tak napr:

    chcem id = 5

    SELECT ... FROM ... WHERE ID >= 3 AND ID <= 7;
    msk avatar 23.6.2009 09:20 msk | skóre: 27 | blog: msk
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    ... co je len nastrel. Messa to napisal spravne.
    23.6.2009 09:27 Jano33
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

     no to je sice pekne, ale problem je ze tie ID nemusia ist za sebou. Co ak je tam [ 1, 5, 8, 10, 15, 50]. LIMITOM dakazem vytiahnut napr 3 zaznamy od 10 nahod, ale co tie nalavo?

    23.6.2009 09:48 marek
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Dobry den.

    Potom muzete ten limit  pouzit dvakrat + union.

    Marek

    23.6.2009 11:31 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    Přesně tak.

    Bohužel MySQL (což tipuji asi bude to, co používáte) neumí LIMIT v poddotazech, takže by nešlo udělat něco jako WHERE id IN (SELECT id FROM tabulka WHERE id <= X LIMIT 3) OR id IN (SELECT id FROM tabulka WHERE id >= X LIMIT 3), což by bylo o něco hezčí.
    23.6.2009 11:34 razor | skóre: 32
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Moje MySQL limit v poddotazu umí.

    23.6.2009 12:23 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    Jakou máš verzi? V 5.0.81 jaksi neběhají.
    23.6.2009 12:32 razor | skóre: 32
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    5.0.70. Jinak v dokumentaci píšou že limit se v subquery může normálně používat. 

    23.6.2009 13:03 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Malý omyl :) ano MySql 5 umí použít LIMIT clausuli v poddotazech, ale již ne ve spojením s IN :( - aspoň doufám, že se to nezměnilo :).

    Lze:

    SELECT * FROM t1
      JOIN (SELECT id FROM t2 ORDER BY id LIMIT 0, 1000) AS t3
        ON (t1.id = t3.id)
    

    Ale NELZE:

    SELECT * FROM t1 WHERE t1.id IN (SELECT id FROM t2 ORDER BY id LIMIT 0, 1000)
    

     

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    23.6.2009 13:13 razor | skóre: 32
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Je to tak. Dík za info.

    23.6.2009 16:20 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Ale lze udělat kličku takto:

    SELECT * FROM t1 WHERE t1.id IN (SELECT * FROM (SELECT id FROM t1 ORDER BY id LIMIT 0, 5) AS t2)
    

    To bude fungovat prostě select s clausulí LIMIT se zapouzdří do selectu bez limitu,
    ale pozor na výkonost při velkých tabulkách a hlavně velké hodnotě v LIMIT.

     

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    23.6.2009 10:31 saslik
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    V Oracle (mozna i jinde) by slo pouzit analyticke funkce LAG a LEAD, ale snadno by to slo pouzit asi jen pro predem znamy rozsah okoli, napr. ty tri zaznamy na kazde strane. Obecne jak uz nekdo navrhoval unionem by to melo byt v pohode pro vetsinu tabulek, pro hodne velke bych to asi resil proceduralne (napr. PLSQL) na platformach kde je takova moznost. Primocare reseni pro predem znamy rozsah by slo pomoci not exists (prvni predchazejici je mensi nez master a neexistuje zadny mezi nimi atd.), coz muze na male tabulce rovnez fungovat, pokud tam bude vhodny index.

    23.6.2009 12:27 Jano33
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

     je to MySQL

    23.6.2009 12:44 Jano33
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Takze spravim to zatial cez dva selekty:

    SELECT * FROM tabulka WHERE id < X order by id desc LIMIT 3

    SELECT * FROM tabulka WHERE id >= X LIMIT 4

    A v PHP to spojim. Bohuzial moja verzia MySQL nepodporuje LIMIT v subquery.

    Vdaka za pomoc.

     

    Jano

     

    23.6.2009 13:14 cronin | skóre: 48
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    Problem nastane, ked sa tabulka zmeni medzi tymi dvomi selectami.
    23.6.2009 13:23 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    A proto používáme InnoDB tabulky, transakce a isolation level READ_COMMITED, jako v každé jiné opravdové databázi :-)
    23.6.2009 13:53 cronin | skóre: 48
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    Ja som len chcel upozornit, aby sa na transakcnost nahodou nezabudlo. ;-)
    24.6.2009 15:25 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    Read commited už podle jména není isolation level, která by vám zajistila, že každý select nebude číst z jiné verze tabulky.
    23.6.2009 16:13 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Zkus radši toto i bez transakce: 15tka je hledane ID Je to takové transparentní a pokud se nejedná o součást nějakého velkého dotazu je to i rychlé (závorky jsou důležité!).
    1. dotaz vezme před 3ks
    2. dotaz vezme pozadovane ID
    3. dotaze vezme po 3ks

    (SELECT id FROM t1 WHERE id > 15 LIMIT 0, 3) 
      UNION 
    (SELECT id FROM t1 WHERE id = 15 LIMIT 0, 1) 
      UNION 
    (SELECT id FROM t1 WHERE id < 15 LIMIT 0, 3)
        ORDER BY id
    

    Neřeší to neexistenci 3 před a 3 po záznamů - nebylo to v dotazu specifikováno.
    dosáhnou výsledku lze více způsoby, jen je třeba se vyhnou 'IN' v MySql.

     Příklad přes PHP je třeba uzavřít do transakce. což není problém pokud se jedná o InnoDB tabulky, na MyIsam bohužel toto není možné.
    Ale pokud se jedná například o web kde jeden zapisuje a mnoho lidí čte a není zklamání dotazu kritické, tak není problém i s takto optimistickým přístupem :).
    Nicméně výkonostně je UNION výrazně rychlejší — jen 1x se komunikuje s MySql serverem.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    23.6.2009 18:57 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

    Malá oprava
    ... doplněno řazení a přehozeni prvního a posledniho selectu aby to odpovídalo popisu výše:

    (SELECT id FROM t1 WHERE id < 15 ORDER BY id DESC LIMIT 0, 3)
      UNION 
    (SELECT id FROM t1 WHERE id = 15 LIMIT 0, 1) 
      UNION 
    (SELECT id FROM t1 WHERE id > 15 ORDER BY id ASC LIMIT 0, 3) 
        ORDER BY id
    

     

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    24.6.2009 11:53 Jano33
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede

     vdaka za rady :)

    Bilbo avatar 24.6.2009 16:49 Bilbo | skóre: 29
    Rozbalit Rozbalit vše Re: SELECT tak aby pozadovane ID bolo v strede
    (SELECT id FROM t1 WHERE id <= 15 ORDER BY id DESC LIMIT 0, 4)
      UNION 
    (SELECT id FROM t1 WHERE id > 15 ORDER BY id ASC LIMIT 0, 3) 
        ORDER BY id
    Misto < tam jde dat <= a zredukovat to tak ze 3 poddotazu na 2. Pokud vim, ze ID existuje, tak bude vysledek stejny, jako u dotazu ze 3 casti. Pokud by ID neexistovalo, dostal bych 4 pred a 3 po.
    Big brother is not watching you anymore. Big Brother is telling you how to live...

    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.