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í
×
    včera 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 0
    19.12. 10:11 | IT novinky

    V pořadí šestou knihou autora Martina Malého, která vychází v Edici CZ.NIC, správce české národní domény, je titul Kity, bity, neurony. Kniha s podtitulem Moderní technologie pro hobby elektroniku přináší ucelený pohled na svět současných technologií a jejich praktické využití v domácích elektronických projektech. Tento knižní průvodce je ideální pro každého, kdo se chce podívat na současné trendy v oblasti hobby elektroniky, od

    … více »
    Ladislav Hagara | Komentářů: 8
    19.12. 03:11 | Komunita

    Linux Foundation zveřejnila Výroční zprávu za rok 2025 (pdf). Příjmy Linux Foundation byly 311 miliónů dolarů. Výdaje 285 miliónů dolarů. Na podporu linuxového jádra (Linux Kernel Project) šlo 8,4 miliónu dolarů. Linux Foundation podporuje téměř 1 500 open source projektů.

    Ladislav Hagara | Komentářů: 0
    19.12. 02:11 | Zajímavý článek

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.12.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    19.12. 02:00 | Nová verze

    OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzi 2.4.0.

    Ladislav Hagara | Komentářů: 0
    19.12. 01:00 | IT novinky

    Kriminalisté z NCTEKK společně s českými i zahraničními kolegy objasnili mimořádně rozsáhlou trestnou činnost z oblasti kybernetické kriminality. V rámci operací OCTOPUS a CONNECT ukončili činnost čtyř call center na Ukrajině. V prvním případě se jednalo o podvodné investice, v případě druhém o podvodné telefonáty, při kterých se zločinci vydávali za policisty a pod legendou napadeného bankovního účtu okrádali své oběti o vysoké finanční částky.

    Ladislav Hagara | Komentářů: 9
    Kdo vám letos nadělí dárek?
     (26%)
     (2%)
     (11%)
     (2%)
     (2%)
     (2%)
     (11%)
     (28%)
     (15%)
    Celkem 53 hlasů
     Komentářů: 16, poslední včera 23:13
    Rozcestník

    Dotaz: [MySQL] dotaz - kde je chyba?

    17.6.2011 10:43 David Sedláček | skóre: 20 | Žďár nad Sázavou
    [MySQL] dotaz - kde je chyba?
    Přečteno: 373×

    Tak tu mam jeden dotaz, kde absolutne nechapu proc nefunguje, resp vim kde je chyba, ale nevim proc :))

    Hned na prvnim SELECTu se vrati vzdycky 0, pritom v one tabulce 100% pozadovany zaznam existuje V podstate to dela to ze to uklada nazvy a jejich odvozene zkratky do tabulky. Pokud je nova zkratka jiz v tabulce, tak se za ni doplni cislo. Uz nad tim sedim hodinu.
    DELIMITER //
    CREATE PROCEDURE VLOZIT_PREDMET(
    	nazev CHAR(255),
    	OUT id INT
    )
    BEGIN
    	DECLARE zkr, zkr_n CHAR(6);
    	DECLARE nalezeno BOOL;
    	DECLARE tmp INT DEFAULT 1;
    	SET zkr=LEFT(LOWER(nazev),3);
    	SET zkr_n=zkr;
    	
    	
    	SELECT COUNT(ID)>0 INTO nalezeno FROM predmety WHERE ZKRATKA=zkr LIMIT 1;
    	WHILE nalezeno=1 DO
    		SET zkr_n=CONCAT(zkr,tmp);
    		SELECT COUNT(ID)>0 INTO nalezeno 
    			FROM predmety 
    			WHERE ZKRATKA=zkr_n LIMIT 1;
    		SET tmp=tmp+1;
    	END WHILE;
    	
    	INSERT INTO predmety (PREDMET, ZKRATKA) 
       		VALUES(nazev, zkr_n);
       	SET id=LAST_INSERT_ID();
         
    END//
    DELIMITER ;
    

    Řešení dotazu:


    Odpovědi

    Tarmaq avatar 17.6.2011 10:59 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    1) neni lepsi misto COUNT(ID)>0 pouzit SIGN(COUNT(ID))? 2) trochu mi unika smysl tohoto reseni, je na to potreba cyklus? Chapu to tak, ze se do tabulky predmety ma vlozit nejblizsi volna zkratka pro dany nazev. Chapu to spravne?
    Don't panic!
    17.6.2011 11:03 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Jestli je to lepsi si nejsem jist, myslim, ze je to to same principielne i vykonove. Chapete to spravne ;)

    Nazvy muzou zacinat podobne, proto tohle reseni.
    Tarmaq avatar 17.6.2011 11:05 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    a co neco jako
    INSERT INTO predmety (
      predmet
    , zkratka
    )
    SELECT
      nazev
    , CONCAT(LEFT(LOWER(nazev), 3), COUNT(0) + 1)
    FROM predmety 
    WHERE predmet = nazev
    GROUP BY predmet
    ;
    
    Don't panic!
    17.6.2011 11:10 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    To zni podstate lip :)) To je elegantnejsi reseni nez to moje. Diky
    17.6.2011 11:17 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Akorat jedna vec - ted se divam ze to vlastne funguje jen pokud uz potencialne duplicitni zaznam existuje - ale porad je potreba zjistit, jestli uz tam je a to by mel zaridit ten radek, na ktery jsem se ptal puvodne.
    Řešení 1× (David Sedláček (tazatel))
    Tarmaq avatar 17.6.2011 11:31 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    aha jasne, a co tohle - zafunguje? (bohuzel nemuzu otestovat)
    INSERT INTO predmety (
      predmet
    , zkratka
    )
    SELECT
      nazev
    , CONCAT(
        LEFT(LOWER(nazev), 3)
      , (
          SELECT COUNT(0) + 1
          FROM predmety
          WHERE predmet = nazev
        )
      )
    ;
    
    PS: to + 1 tam byt nemusi, chces-li cislovat od nuly
    Don't panic!
    17.6.2011 11:40 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Je to tam :)
    17.6.2011 12:38 kuka
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Jen poznamka - pri paralelim spusteni mohou vzniknout duplicitni nazvy (pokud neni nekde okolo nejake zamykani apod.).
    Tarmaq avatar 17.6.2011 12:46 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    nebo slozeny primarni klic nad tabulkou predmety, pripadne unique constraint atp.
    Don't panic!
    17.6.2011 12:56 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Tak ta procedura pojede v transakci, takze predpokladam, ze tim je tohle osetreno.
    3.7.2011 11:02 kuka
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Tim to rozhodne osetreno neni. Prave proto, ze zmena bude pro ostatni viditelna az po commitu, vyberou si obe soucasne bezici transakce stejny nazev, protoze budou vychzet ze stejneho stavu databaze.
    2.7.2011 18:02 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Ozivuji tohle tema, protoze uzce souvisi s mym problemem a v podstate se tim odpovi na muj puvodni dotaz - proc je v promenne nalezeno hodnota NULL ???

    Radek
    	SELECT COUNT(ID)>0 INTO nalezeno FROM predmety WHERE ZKRATKA=zkr LIMIT 1;

    Pokud si tentyz prikaz pustim v konzoli, dela co ma, ale v tehle procedure ne. Ted jsem na to narazil podruhe a uz nad tim sedim X hodin a stale to nemohu vyresit. Znovu opakuji - ten statement jinak vraci hodnotu, ale v tomhle pripade nic, nalezeno je NULL. Fakt nevim co s tim uz.

    Tohle je tentyz pripad:
    	SET nalezeno=(SELECT COUNT(ID)>0 FROM predmety WHERE ZKRATKA=zkr LIMIT 1)
    2.7.2011 18:18 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [MySQL] dotaz - kde je chyba?
    Ted jsem zjistil, ze do te promenne se nic nevlozi i kdyz je dotaz bez pominky
    SELECT ID INTO nalezeno FROM predmety LIMIT 1;

    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.