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ářů: 5
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ářů: 10
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (3%)
 (74%)
 (3%)
 (10%)
Celkem 313 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

    Dotaz: php a náhrada die

    22.9.2011 16:14 Jarek
    php a náhrada die
    Přečteno: 700×
    Ahoj, jak můžu nahradit tohle
    mysql_query($sql) OR die("Chyba!");
    nevím co je dobře
    $mysql_query = mysql_query($sql);
    if(!$mysql_query) {
    # chyba
    }
    nebo
    $mysql_query = mysql_query(($sql),0);
    if($mysql_query ==0) {
    # chyba
    }
    
    nebo
    $mysql_query = mysql_query(($sql),0);
    if($mysql_query === false) {
    # chyba
    }
    poradíte?

    Děkuji

    Odpovědi

    Jendа avatar 22.9.2011 16:48 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: php a náhrada die
    Podmínka je u všech příkladů stejná (až na ty tři = u posledního).

    Jaké parametry chceš nakrmit mysql_query() musíš vědět sám. Pokud máš současně vždy jen jedno spojení s databází, nemusíš druhý parametr uvádět.
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    Tarmaq avatar 22.9.2011 17:23 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: php a náhrada die
    if (!$resource = mysql_query($sql)) {
      #chyba
    }
    
    Don't panic!
    22.9.2011 18:08 Kit
    Rozbalit Rozbalit vše Re: php a náhrada die
    if(!$result=mysql_query($sql)) throw new Exception("Chyba!");
    Josef Kufner avatar 22.9.2011 23:44 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: php a náhrada die
    Return Values

    For SELECT, SHOW, DESCRIBE, EXPLAIN and other statements returning resultset, mysql_query() returns a resource on success, or FALSE on error.

    For other type of SQL statements, INSERT, UPDATE, DELETE, DROP, etc, mysql_query() returns TRUE on success or FALSE on error.
    Takže správně je:
    $result = mysql_query($query, $connection);
    if ($result === FALSE) {
       // Chyba
    } else {
       // Uspech
    }
    Pak je otázkou, zda je chyba vážná nebo ne. Pokud děláš select, tak tam asi budeš chtít pomocí error_log() zaznamenat detaily o chybě. Pokud to je insert/update, tak jsi třeba jen narazil duplicitou na unikátní klíč a 'chyba' je vlastně v pořádku.

    Ale asi nejlepší je použít nějakou nadstavbu, třeba dibi.
    Hello world ! Segmentation fault (core dumped)
    23.9.2011 10:13 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: php a náhrada die
    To není tak úplně třeba, protože nic jiného co by se vyhodnotilo jako FALSE (0,'', NULL…) to vrátit nemůže, buď je to resultset, nebo TRUE nebo FALSE.
    Něco jiného by to bylo například u mysqli_fetch.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Josef Kufner avatar 24.9.2011 23:02 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: php a náhrada die
    To sice jo, ale je to spíš náhoda, než že by se na to dalo spolehnout. Pokud se v dokumentaci píše, že to vrátí FALSE, tak tam patří '==='. Je to celkem častý zdroj chyb, které se těžko hedají.
    Hello world ! Segmentation fault (core dumped)
    xkucf03 avatar 24.9.2011 23:21 xkucf03 | skóre: 45 | blog: xkucf03
    Rozbalit Rozbalit vše Re: php a náhrada die
    Doporučuji použít PDO – je univerzálnější (ne jen pro MySQL). Pak to bude vypadat nějak takhle:
    try {
    	$dotaz = $pdo->prepare($sql);
    	$dotaz->execute();
    	$r = $dotaz->fetchAll();
    	/** uděláme něco s výsledkem */	
    } catch (PDOException $e) {
    	/** uděláme něco s chybou */
    }
    A před execute() ještě nastavíš parametry dotazu (nebudeš je vkládat do textu SQL):
    $dotaz->bindParam($parametr, $jehoHodnota);
    $parametr je buď pořadí (od 1) nebo název parametru – do SQL dáš třeba
    SELECT * FROM tabulka WHERE id = :nazevParametru
    nebo tam dáš jen otazník a odkážeš se na parametr podle jeho pořadí.

    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-Výuka.cz, Nekuřák.net
    Josef Kufner avatar 25.9.2011 09:59 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: php a náhrada die
    Na sestavování selectů je povětšinou potřeba něco mnohem mocnějšího. Připravené dotazy ti nepomůžou s přidáváním podmínek, když chceš filtrovat podle různých kritérií při různém použití dotazu.

    Dibi fluent:
    $q = dibi::select('t.id, t.name, t.address')
         ->from('`table` t');
    if ($show_last_month_only) {
         $q->where('t.mtime > NOW() - INTERVAL 1 MONTH');
    }
    if ($city != '') {
         $q->leftJoin('`address` a')->on('a.id = t.address');
         $q->where('a.city = %s', $city);
    }
    if ($count > 0) {
         $q->limit($count, $offset);
    }
    
    Jakpak by to asi vypadalo, kdyby se lepily kousky stringů dohromady? A jak by se takový slepenec rozšiřoval o další možnosti filtrování?
    Hello world ! Segmentation fault (core dumped)
    xkucf03 avatar 25.9.2011 10:51 xkucf03 | skóre: 45 | blog: xkucf03
    Rozbalit Rozbalit vše Re: php a náhrada die
    To je samozřejmě další stupeň abstrakce a odstínění od „nízkoúrovňového“ SQL (což je v něčem užitečné a v něčem naopak škodlivé). Stejně tak lze poradit ORM typu Hibernate/JPA :-) Ale když vidím, jak tazatel používá funkce typu mysql_query(), tak mi přijde nevhodné přeskočit tolik vrstev a radit rovnou tyhle vysokoúrovňové věci (jednak nejsou vždy tím nejlepším řešením a jednak je lepší, když si tím člověk projde postupně a nepřeskakuje).
    Jakpak by to asi vypadalo, kdyby se lepily kousky stringů dohromady? A jak by se takový slepenec rozšiřoval o další možnosti filtrování?
    1) Tyhle dynamické (strukturou) dotazy jsou celkem výjimečná věc – ve většině aplikace si vystačíš s SQL, které je vždy stejné a liší se jen parametry (a ty dynamické budeš potřebovat jen v nějakém vyhledávání resp. filtru, kde uživatel zadává různé podmínky).

    2) SQL se dá poslepovat z kousků textu, kdy ale lepšíš jen (bezpečné) názvy sloupců a otazníky (nebo zástupky typu :parametr1), ale ne (nebezpečná) data od uživatele – ta tam dostaneš parametrizací dotazu. Pořád je to lepší, než způsob, jakým velká část lidí na webu „programuje“ :-)
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-Výuka.cz, Nekuřák.net
    Josef Kufner avatar 25.9.2011 11:17 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: php a náhrada die
    Ne, tohle není žádná vyšší abstrakce. To je jen chytřejší cat (spojování stringů), který využívá znalost syntaxe SQL dotazu. Nic víc. Viz kód toho lepení.

    Výpisy seznamu položek filtrovaných podle různých kritérií jsou, tedy alespoň na webu, velmi časté. Odhaduju to tak na třetinu dotazů psaných programátorem (pokud nepoužívá nějaké ORM). Většinou se dotazy liší jen málo, střídají se jednoduché podmínky ve where, někdy v kombinaci s triviálním joinem.
    Hello world ! Segmentation fault (core dumped)
    25.9.2011 11:30 Kit
    Rozbalit Rozbalit vše Re: php a náhrada die
    Nikde nevidím ošetření chyb, na které se tazatel ptal a které Dibi jistě nabízí. Kromě toho je uvedený příklad na můj vkus příliš komplikovaný a působí spíš jako spam na Dibi než jako řešení selhání dotazu SQL. A že může selhat dotaz i v Dibi, je snad jasné.
    28.9.2011 08:43 VM
    Rozbalit Rozbalit vše Re: php a náhrada die
    V PHP lze napsat:

    funkce() or die();

    ale nelze napsat:

    funkce() or moje_obsluha();

    Dal jsem jim na to bugreport, ale odmítli se tím zabývat, takže to asi v dohledné době nepůjde.

    Mimochodem v PHP je podobných bastů daleko víc, například nedodělané lambda funkce přes create_function() pro array_map() - ve srovnání s předlohou v Perlu toho umí míň, a jsou naimplementované tak špatně, že je v oficiálním manuálu ani nedoporučují používat.
    Tarmaq avatar 28.9.2011 13:13 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: php a náhrada die
    Vazne? Tohle
    function foo()
    {
        print(__METHOD__);
        return false;
    }
    function bar()
    {
        print(__METHOD__);
        return true;
    }
    foo() or bar();
    
    mi vypise:
    foobar
    Don't panic!
    28.9.2011 18:16 Non_E | skóre: 24 | blog: hic_sunt_leones | Pardubice
    Rozbalit Rozbalit vše Re: php a náhrada die
    Funkce create_function nebyla nikdy povedená. Na druhou stranu se php jako jazyk stále vyvíjí. Zkus od php 5.3 jako callback použít skutečnou anonymní funkci.

    Výraz foo() or bar() samozřejmě funguje, nefunguje foo() or throw new \Exception.
    Only Sith deals in absolutes.

    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.