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 17:25 | IT novinky

Do prodeje (Farnell) se dostal jednodeskový počítač Tinker Board (unboxing). Jedná se o konkurenci Raspberry Pi 3 od společnosti Asus. Porovnání (jpg) těchto počítačů například na CNXSoft. Cena Tinker Boardu je 55 £.

Ladislav Hagara | Komentářů: 2
dnes 14:44 | Zajímavý projekt

Byla zveřejněna pravidla hackerské soutěže Pwn2Own 2017, jež proběhne od 15. do 17. března v rámci bezpečnostní konference CanSecWes ve Vancouveru. Soutěžit se bude o více než milion dolarů v pěti kategoriích. Letos se bude útočit i na Ubuntu. Jedná se již o 10. ročník této soutěže.

Ladislav Hagara | Komentářů: 1
dnes 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 0
dnes 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
dnes 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
včera 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

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

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

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

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 7
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (11%)
 (2%)
 (73%)
 (3%)
 (10%)
Celkem 381 hlasů
 Komentářů: 31, poslední dnes 19:19
Rozcestník
Reklama

Dotaz: Rozdílné výsledky SQL dotazu ve Workbench/php

28.9.2014 20:45 cndr
Rozdílné výsledky SQL dotazu ve Workbench/php
Přečteno: 287×
Hezký večer

mám komplikovanější dotaz který v sekci SELECT používá dočasné proměnné kterým se přiřadí hodnota v sekci WHERE. Když dotaz spustím v mysql Workbench, dotaz vždy proběhne bez potíží a varování. Když tentýž dotaz přenesu do PHP, spustím tak dostanu NULL, kde se vyskytují dočasné proměnné v sekci SELECT. Kde mám hledat chybu? Mám zapnutý kompletní log serveru mysql, a z logu vidím, že jsou dotazy zcela identické ale návratové hodnoty různé. (Jasně, že data nejsou mezi dotazy ničím modifikovány!)

Příklad:
 SELECT @a, @b FROM (SELECT 1) as t WHERE (@a := 1) > 0 AND (@b := 2) > 0
Jarda

PS: Je to jen výřez dotazu tam kde je FROM je ve skutečnosti spojeno několik tabulek, a za tím přiřazením do @a, @b je ve skutečnosti nějaká uživatelská funkce kterou volán s parametry a další komplikovanější test, a poněvadž ji musím otestovat ale i zároveň vrátit její hodnotu, používám ty dočasné proměnné (ať se to nespouští 2x v jednom dotazu).

PPS: Pro hloubání je zde plná verze dotazu:
SELECT
    IF(@a > 1,
        CONCAT(`c`.`service`, ' na ', @a, ' m.'),
        `c`.`service`) AS `service`,
    @a * @b AS `valuea`,
    CONCAT(`tb`.`day`,
            '.',
            9,
            '. ',
            2014) AS `date_to`,
    IFNULL(`b`.`name`, `b`.`firm`) AS `name`,
    `b`.`last_name`,
    `b`.`street`,
    `b`.`street_no`,
    `t`.`town`,
    `t`.`psc`,
    `a`.`account` AS `accounta`,
    `k`.`no` AS `ca`,
    CASE `a`.`symbola`
        WHEN 2 THEN `s`.`no_cotract`
        WHEN 1 THEN `s`.`symbol`
        ELSE ''
    END AS `ntracta`,
    CASE `a`.`symbolb`
        WHEN 2 THEN `s`.`no_cotract`
        WHEN 1 THEN `s`.`symbol`
        ELSE ''
    END AS `symbola`
FROM
    `services` `s`
        INNER JOIN
    `contacts` `co` ON (`co`.`id_contact` = `s`.`id_contact`)
        INNER JOIN
    `type_payments` `tp` USING (`id_type_payment`)
        INNER JOIN
    `type_billings` `tb` USING (`id_type_billing`)
        INNER JOIN
    `billings` `b` USING (`id_billing`)
        INNER JOIN
    `concat_service_def` `c` USING (`id_service_def`)
        INNER JOIN
    `towns` `t` ON (`t`.`id_town` = `b`.`id_town`)
        INNER JOIN
    `bills_towns` `bt` ON (`b`.`id_town` = `bt`.`id_town`)
        INNER JOIN
    `bills` `a` ON (`a`.`id_bill` = `bt`.`id_bill`
        AND `bt`.`id_type_service` = `c`.`id_type_service`)
        INNER JOIN
    `banks` `k` ON (`k`.`id_bank` = `a`.`id_bank`)
WHERE
    `tp`.`type_payment` = 2
        AND IFNULL(YEAR(`s`.`deleted`) <= 2014, TRUE)
        AND IFNULL(MONTH(`s`.`deleted`) < 9, TRUE)
        AND `co`.`id_town` = 3 AND
        (@a := (`month_for_bil`(`s`.`id_service`, 2014, 9) + 3)) > 0 AND
        (@b := (`price_service`(`s`.`id_service_def`, CONCAT('2014-9-', day)))) > 0

Řešení dotazu:


Odpovědi

28.9.2014 20:59 Kit | skóre: 37 | Brno
Rozbalit Rozbalit vše Re: Rozdílné výsledky SQL dotazu ve Workbench/php
Zkusil jsem si ten první příkaz a dostal jsem NULL, NULL. Když jsem ho spustil znovu, dostal jsem 1, 2. Zřejmě je to proto, že proměnné @a, @b musí být předem deklarovány. Potom už deklarovány jsou.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
28.9.2014 21:30 cndr
Rozbalit Rozbalit vše Re: Rozdílné výsledky SQL dotazu ve Workbench/php
Heuréka, to bude asi ono! Ten testovací dotaz jsem přebral z nějakého serveru na optimalizaci dotazů a tvrdili, že to funguje. Vysvětlení je prosté ve Workbenchu jsem přihlášen trvale, takže si ty proměnné pamatuje z jiných dotazů.

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.