Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).
Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.
Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.
Byla vydána nová verze 1.25 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.
Byla vydána beta verze Linux Mintu 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.
Provozovatel internetové encyklopedie Wikipedie prohrál v Británii soudní spor týkající se některých částí nového zákona o on-line bezpečnosti. Soud ale varoval britského regulátora Ofcom i odpovědné ministerstvo před zaváděním přílišných omezení. Legislativa zpřísňuje požadavky na on-line platformy, ale zároveň čelí kritice za možné omezování svobody slova. Společnost Wikimedia Foundation, která je zodpovědná za fungování
… více »Byla vydána verze 2.0.0 nástroje pro synchronizaci dat mezi vícero počítači bez centrálního serveru Syncthing (Wikipedie). Přehled novinek na GitHubu.
Americký prezident Donald Trump se v pondělí osobně setkal s generálním ředitelem firmy na výrobu čipů Intel Lip-Bu Tanem. Šéfa podniku označil za úspěšného, informují agentury. Ještě před týdnem ho přitom ostře kritizoval a požadoval jeho okamžitý odchod. Akcie Intelu v reakci na schůzku po oficiálním uzavření trhu zpevnily asi o tři procenta.
$dis = array('a', 'b', 'c');a chtěl bych pomocí PDO vypsat řádky z mysql za podmínek když dejme tomu, že v poli budou tři hodnoty a,b,c:
name = a, b, ca
sign = 0, 1, 2ale nevím jak na to
$stmt = $pdo->prepare('SELECT * FROM data WHERE name = ? sign = ?;'); $stmt->execute(array(???, ???)); $result = $stmt->fetchAll(PDO::FETCH_ASSOC | PDO::FETCH_GROUP);čili první řádek
name = a AND sign = 0druhý řádek
name = b AND sign = 1třetí řádek
name = c AND sign = 2poradí někdo? Děkuji
SELECT * FROM data WHERE name = ? ORDER BY sign;
SELECT * FROM data WHERE name = a sign = 0; SELECT * FROM data WHERE name = b sign = 1; SELECT * FROM data WHERE name = c sign = 2;
SELECT * FROM data WHERE (name = ? AND sign = ?) OR (name = ? AND sign = ?) OR (name = ? AND sign = ?); ... $stmt->execute(array(a, 0, b, 1, c, 2));
$name = array('a','b','c','d');
$sign = array(1,2,3,4);
$query = "SELECT * FROM data";
$params = array();
for($i=0;$i< count($name);$i++){
if($i>0){
$query .= " OR";
}else{
$query .= " WHERE";
}
$query .= " (name = ? AND sign = ?)";
$params[] = $name[$i];
$params[] = $sign[$i];
}
//print $query;
$stmt = $pdo->prepare($query);
$stmt->execute($params);
$result = $stmt->fetchAll(PDO::FETCH_ASSOC | PDO::FETCH_GROUP);
$params = array(); // nova promenna -> pole hodnot, ktere budeme bindovat for($i=0;$i< count($name);$i++){ // od nuly po delku pole (indexy zacinaji od nuly) if($i>0){ // druha az Nta podminka, tak pridame spojku OR $query .= " OR"; }else{ // je to prvni podminka, tak musime pridat WHERE $query .= " WHERE"; } $query .= " (name = ? AND sign = ?)"; // zakladni struktura podminky, pro osetreni parametru (prepared statements) dame ? // a promenne pridame do pole hodnot, prvni je name, druhe je sign -> dva otazniky, dve nove hodnoty $params[] = $name[$i]; $params[] = $sign[$i]; }
<?php $rows = array( array('a', 0), array('b', 1), array('c', 2), array('d', 3), ); $sql = "SELECT * FROM data WHERE " . implode(' OR ', array_map(function ($a) { return '(name = ? AND sign = ?)'; }, $rows) ); echo $sql, "\n"; $params = array(); foreach($rows as $row){ $params[] = $row[0]; $params[] = $row[1]; } print_r($params);
$names = array('a','b','c','d'); $params = array(); foreach($names as $key => &$item){ $params[] = $item; $params[] = $key; $item = "(name = ? AND sign = ?)"; } $sql = "SELECT * FROM data WHERE ".implode(' OR ', $names); echo $sql, "\n"; print_r($params);
$ot = array('?', '?', '?'); $name = array('a', 'b', 'c'); $sign = array('0', '1', '2'); $stmt = $pdo->prepare('SELECT * FROM data WHERE name IN($ot) AND sign IN($ot);'); $stmt->execute(array($name, $sign)); $result = $stmt->fetchAll(PDO::FETCH_ASSOC | PDO::FETCH_GROUP);
$ot = "?, ?, ?"; $name = array('a', 'b', 'c'); $sign = array('0', '1', '2'); $stmt = $pdo->prepare('SELECT * FROM data WHERE name IN($ot) AND sign IN($ot);'); $stmt->execute(array_merge($name, $sign)); $result = $stmt->fetchAll(PDO::FETCH_ASSOC | PDO::FETCH_GROUP);
name = 'a' AND sign = '0' name = 'b' AND sign = '1' name = 'c' AND sign = '2'Pkud bude v poli prvků 10, tak vrátit deset řádků z mysql. name a sign jsou názvy sloupců, přičemž hodnoty v poli $name se mění ale druhá podmínka pro sloupec sign je vždy pozice prvku v poli $name. Snad jsem to napsal k pochopení
name a sign jsou názvy sloupců, přičemž hodnoty v poli $name se mění ale druhá podmínka pro sloupec sign je vždy pozice prvku v poli $nameTakže
sign
je unikátní klíč a pro každé sign
je právě jedno name
(array($sign => $name)
)? Pak stačí WHERE sign IN (0, 1, 2)
.
SELECT * FROM data WHERE (name, sign) IN (?, ?);K tomuto dotazu byste pak připojil pole dvojic
array(array('a', 0), array('b', 1), array('c', 2))
.
Pokud vím, MySQL ale tuhle syntaxi nepodporuje. Některé frameworky to v takovém případě řeší tak, že ten dotaz sestaví samy. Tj. spočítají počet prvků pole, a podle toho pak vytvoří
SELECT * FROM data WHERE (name = ? AND sign = ?) [OR (name = ? AND sign = ?)…];Pokud MySQL tu syntaxi s vektorem v
IN
nepodporuje, asi budete muset použít to vytváření dotazu na míru. Pozor také na to, že počet položek v IN
může být omezený. Ale nedává smysl, abyste tam měl stovky položek, to by pak vypadalo spíš na špatný návrh aplikace, kdy si předáváte nějaké hodnoty přes aplikaci, místo abyste použil JOIN
.
Tiskni
Sdílej: