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 01:33 | Zajímavý projekt

    Od 1. ledna 2026 jsou všechny publikace ACM (Association for Computing Machinery) a související materiály přístupné v její digitální knihovně. V rámci této změny je nyní digitální knihovna ACM nabízena ve dvou verzích: v základní verzi zdarma, která poskytuje otevřený přístup ke všem publikovaným výzkumům ACM, a v prémiové zpoplatněné verzi, která nabízí další služby a nástroje 'určené pro hlubší analýzu, objevování a organizační využití'.

    NUKE GAZA! 🎆 | Komentářů: 2
    včera 16:44 | IT novinky

    S koncem roku 2025 skončila standardní podpora operačního systému HP-UX (Hewlett Packard Unix).

    Ladislav Hagara | Komentářů: 5
    včera 14:33 | Nová verze

    K 1. lednu 2026 končí 70leté omezení majetkových autorských práv děl autorů zesnulých v roce 1955, viz 2026 in public domain. V americkém prostředí vstupují do public domain díla z roku 1930, viz Public Domain Day.

    |🇵🇸 | Komentářů: 1
    31.12. 15:00 | Nová verze

    Všem vše nejlepší do nového roku 2026.

    Ladislav Hagara | Komentářů: 10
    31.12. 13:33 | Zajímavý software

    Crown je multiplatformní open source herní engine. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT a GPLv3+. Byla vydána nová verze 0.60. Vyzkoušet lze online demo.

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

    Daniel Stenberg na svém blogu informuje, že po strncpy() byla ze zdrojových kódů curlu odstraněna také všechna volání funkce strcpy(). Funkci strcpy() nahradili vlastní funkcí curlx_strcopy().

    Ladislav Hagara | Komentářů: 6
    31.12. 03:00 | Nová verze

    Byla vydána nová verze 25.12.30 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    30.12. 18:55 | IT novinky

    Společnost Valve publikovala přehled To nej roku 2025 ve službě Steam aneb ohlédnutí za nejprodávanějšími, nejhranějšími a dalšími nej hrami roku 2025.

    Ladislav Hagara | Komentářů: 0
    30.12. 16:11 | Komunita

    Byly publikovány výsledky průzkumu mezi uživateli Blenderu uskutečněného v říjnu a listopadu 2025. Zúčastnilo se více než 5000 uživatelů.

    Ladislav Hagara | Komentářů: 0
    30.12. 03:33 | Bezpečnostní upozornění

    V dokumentově orientované databázi MongoDB byla nalezena a v upstreamu již opravena kritická bezpečností chyba CVE-2025-14847 aneb MongoBleed.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (0%)
     (0%)
     (0%)
     (17%)
     (50%)
     (17%)
     (0%)
     (0%)
     (33%)
     (50%)
    Celkem 6 hlasů
     Komentářů: 1, poslední dnes 06:15
    Rozcestník

    Dotaz: Oprava php kódu

    21.5.2014 22:54 Dr
    Oprava php kódu
    Přečteno: 456×
    Ahoj, opraví mi prosím někdo tento kód ? Fakt už nevím jak :-( Díky
    $ids = '2,6,12,15,13,14,7,8,9,10,';
    $stmt = $pdo->prepare('SELECT * FROM table WHERE col IN (?) ORDER BY ID ASC;');
    $stmt->execute(array($ids));

    Odpovědi

    22.5.2014 00:10 Lucius
    Rozbalit Rozbalit vše Re: Oprava php kódu
    $ids udelej rovnou jako pole - $ids = array(2,6,12,15,13,14,7,8,9,10)

    a pokud to neni mozne tak ten retezec $ids prozen pres fu explode -ta vraci pole

    explode(',',$ids);

    http://cz1.php.net/explode
    22.5.2014 00:24 Dr
    Rozbalit Rozbalit vše Re: Oprava php kódu
    Jako takto? To nefunguje..
    $ids = array(2,6,12,15,13,14,7,8,9,10);
    $stmt = $pdo->prepare('SELECT * FROM table WHERE col IN (?) ORDER BY ID ASC;');
    $stmt->execute($ids);
    tohle funguje ale je mi to k ničemu :-(
    $stmt = $pdo->prepare('SELECT * FROM table WHERE col IN (2,6,12,15,13,14,7,8,9,10) ORDER BY ID ASC;');
    $stmt->execute();
    wamba avatar 22.5.2014 01:24 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Oprava php kódu
    V dokumentaci pro Perl knihovnu DBI se píše

    Also, placeholders can only represent single scalar values. For example, the following statement won't work as expected for more than one value:
    "SELECT name, age FROM people WHERE name IN (?)"    # wrong
    a předpokládám, že v PHP to bude podobné. Tedy pokud je to náhodný počet libovolných čísel, tak pravděpodobně budete muset spouštět prepare pro každé $ids zvlášť.
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    22.5.2014 10:53 Lucius
    Rozbalit Rozbalit vše Re: Oprava php kódu
    Pokud se nepletu,tak potrebujes ten jeden otaznik v IN (?) nahradit poctem hodnot v $ids

    takze

    'SELECT * FROM table WHERE col IN (?) ORDER BY ID ASC;'

    by melo vypadat nejak takto

    $ids = array(2,6,12,15,13,14,7,8,9,10);

    SELECT * FROM table WHERE col IN ('.trim(str_repeat ("?,", count($ids)),',').') ORDER BY ID ASC;

    Je to jen nastrel, nemam to ted kde kontrolovat, ale tak nejak by to melo jit
    23.5.2014 11:40 Logik
    Rozbalit Rozbalit vše Re: Oprava php kódu
    To jde, pokud v dotazu nejsou další proměnný na bindování, jinak se z toho člověk pak zvence při bindování.

    Jde se taky na bindování vykašlat a sestavit dotaz:
    $query=$pdo->prepare(
      'SELECT * FROM table WHERE col IN ('
      .implode(',', array_map(array($pdo, 'quote'), $ids)) . 
      ') ORDER BY ID ASC;'
    );
    23.5.2014 12:21 Lucius
    Rozbalit Rozbalit vše Re: Oprava php kódu
    Proc? $ids v tom prikladu je uzavrena mnozina, ktera je jen podmnozinou vsech parametru - jediny rozdil by byl v tom, ze u takto jednoducheho dotazu je vlastne $ids zaroven i polem vsech parametru, pokud by mel dlalsi parametry tak proste $ids spoji s polem pro dalsi parametry.
    23.5.2014 12:33 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Oprava php kódu
    My vlastně ani nevíme, kde se vzala proměnná $ids. Určitě ji takto neplní. Možná je to uživatelský vstup, možná výsledek dotazu v databázi. Každý případ se řeší jinak.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    23.5.2014 12:40 Lucius
    Rozbalit Rozbalit vše Re: Oprava php kódu
    To jiste, ale nez se dostane k prepare tak je uzavrena - je jedno odkud prijde, proste ve chvili prepare ma pevne dane hodnoty - takze to muze zpracovat jak jsme tu uvadeli reseni tu ma vic a pokud bude mit sql nejake dlasi parametry , tak je proste po tom zpracovani spoji s $ids. Kdyz si na to napise nejakou fu, tak to muze mit i docela pekne integrovatelne do jakehokoli kodu.
    23.5.2014 12:46 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Oprava php kódu
    Spíš bych ji označil za serializovanou. Taková práce s daty není zrovna standardní.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    22.5.2014 11:26 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Oprava php kódu
    $ids = array(2, 6, 12, 15, 13, 14, 7, 8, 9, 10);
    $sql = "SELECT * FROM table WHERE col IN (" .
        implode(", ", array_fill(0, count($ids), "?")) .
        ") ORDER BY ID ASC;";
    $stmt = $pdo->prepare($sql);
    $stmt->execute($ids);
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    22.5.2014 16:15 Dr
    Rozbalit Rozbalit vše Re: Oprava php kódu
    Díky chlapáci a můžu nějak ten SELECT již nahrazené otazníky za hodnoty nějak vidět? Zkoušel jsem var_dump() ale tam vidím jen otazníky. Díky moc.
    22.5.2014 16:39 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Oprava php kódu
    Však ty otazníky se nahrazují na serveru až po kompilaci SQL dotazu.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    22.5.2014 18:34 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Oprava php kódu

    Zjednodušeně: nemůže protože to v zásadě neexistuje, MySQL server má dotaz s otazníky + sadu hodnot a vnitřně si to tam dosadí ... juk.

    Nicméně to bala trochu „lež dětem“, pro dospělé je to trochu zamotanější na více úrovních, například dle PDO::ATTR_EMULATE_PREPARES lze zjistit (a nastavit) jestli, jsou to prováděné „server-side“ připravené dotazy nebo to PDO emuluje a tedy teoreticky, ten kompletní dotaz existuje sestavený na úrovni PDO.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    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.