abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 2
    včera 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

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

    Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.

    Fluttershy, yay! | Komentářů: 0
    včera 13:11 | IT novinky

    Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.

    Ladislav Hagara | Komentářů: 2
    6.5. 21:33 | Komunita

    Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.

    Ladislav Hagara | Komentářů: 5
    6.5. 21:11 | IT novinky

    Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.

    Ladislav Hagara | Komentářů: 1
    6.5. 17:55 | Nová verze

    AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.5. 17:11 | IT novinky

    Před 50 lety, 5. května 1974 v žurnálu IEEE Transactions on Communications, Vint Cerf a Bob Kahn popsali protokol TCP (pdf).

    Ladislav Hagara | Komentářů: 0
    6.5. 13:44 | Zajímavý článek

    Bylo vydáno do češtiny přeložené číslo 717 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (63%)
     (8%)
     (14%)
     (16%)
    Celkem 133 hlasů
     Komentářů: 9, poslední včera 22:07
    Rozcestník

    Dotaz: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.

    23.3.2014 20:37 Marián
    PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Přečteno: 283×
    Ahoj, mám ještě jeden dotaz ohledně tohoto pole
         $array = array('aaa' => array('a' => 'a-aaa', 'b' => 'b-aaa'),
                        'bbb' => array('a' => 'a-bbb', 'b' => 'b-bbb'),
                        'ccc' => array('a' => 'a-ccc', 'b' => 'b-ccc'),
                        'ddd' => array('a' => 'a-ddd', 'b' => 'b-ddd'),
                        'eee' => array('a' => 'a-ccc', 'b' => 'b-eee'));
    Zkouším získat klíč podle zadaného údaje, Zkoušel jsem to
    echo array_search('a-bbb', $array);
    i takto
    echo array_search('a-bbb', array($array));
    ale vůbec nic mi nejde. Poradí někdo? Díky

    Odpovědi

    23.3.2014 20:51 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Proč si ho raději nevytáhneš z databáze?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    23.3.2014 22:53 Marián
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    To jsem zkoušel, ale taky to nejde...
         $stmt = $db->prepare('SELECT key FROM table WHERE co = ?;');
         $stmt->execute(array('a-aaa'));
         $status = $stmt->fetch();
         echo $status['key'];
    
    zkoušel jsem i tohle
         $stmt = $db->prepare('SELECT key FROM table WHERE co = ?;');
         $stmt->execute(array('a-aaa'));
         $status = $stmt->fetchColumn();
         echo $status['key'];
    
    ale taky nic. Když dám var_dump($status); tak to vrací jen "bool(false)". Když dám místo key hvězdičku, tak to funguje...

    Vydí tam někdo nějakou chybu? Díky
    23.3.2014 23:33 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Skutečně se ten sloupeček v databázi jmenuje "key"? Proč vlastně hledáš klíč podle hodnoty a ne obráceně? Mám takové tušení, že ten návrh aplikace máš zcela špatně.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    24.3.2014 01:40 Marián
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Ano, opravdu se jmenuje "key". Pokud zadám místo "key" "*" tak to funguje :-( Klíč hledám podle hodnoty proto, jelikož znám daný kousek české url ale neznám fyzicky us název souboru.
    Jendа avatar 24.3.2014 01:45 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    No a když to napíšeš přímo do konzole databázového serveru, tak to něco vrátí?
    24.3.2014 11:34 Marián
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Ano vrátí to chybu:

    ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'key FROM define WHERE co = a-aaa' at line 1

    ale žádnou chybu nevidím..
    24.3.2014 12:13 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    key je nevhodné označení sloupce rezervovaným slovem - zadej `key` .
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    24.3.2014 13:51 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.

    Toto je přesně případ, proč raději vše uvozovkuji, těmi uvozovkami, které dané entitě v daném DBE přísluší. minimálně je třeba použít lepší názvy, tedy key doplnit o to co je to za key, třeba userLoginKey nebo book_category_key .

    Uvozovkování předchází i problému, kde se vytvoří nové rezervované slovo, ale zas to pro někoho znepřehledňuje dotazy.

    Zadej 'SELECT `key` FROM `table` WHERE `co` = ?;' (pro MySQL) a už to pojede
    (Pro PostgreSQL by to bylo něco jako: 'SELECT "key" FROM "table" WHERE "co" = ?;',
    pro M$SQL myslím něco jako 'SELECT [key] FROM [table] WHERE [co] = ?;').

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Jendа avatar 23.3.2014 21:17 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Protože array_search() nejde do hloubky. Zkusil bych něco jako
    foreach a in $array {
      echo array_search('a-bbb', $a);
    }
    (pseudokód)

    Pro víc polí to bude pomalé, pak bych asi uvažoval o nějaké vhodnější struktuře (strom, hashtable).
    26.3.2014 12:56 Lucius
    Rozbalit Rozbalit vše Re: PHP - Jak vrátit key z vnořeného pole podle známé hodnoty.
    Pokud jde o index toho vnejsiho pole tak nejak takto by to melo jit:
    $source = array('aaa' => array('a' => 'a-aaa', 'b' => 'b-aaa'),
                        'bbb' => array('a' => 'a-bbb', 'b' => 'b-bbb'),
                        'ccc' => array('a' => 'a-ccc', 'b' => 'b-ccc'),
                        'ddd' => array('a' => 'a-ddd', 'b' => 'b-ddd'),
                        'eee' => array('a' => 'a-eee', 'b' => 'b-eee'));
    
    $output=''; // index pole pro nalezenou hodnotu
    $find = 'a-eee'; // hledana hodnota
    
    array_walk(array_keys($source),create_function('$value, $key,$param', 'in_array($param[1], $param[0][$value])? $param[2] = $value: "";'),array($source,$find,&$output)); 
    
    echo $output;

    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.