Zero Day Initiative zveřejnila informace o 6 bezpečnostních chybách (1, 2, 3, 4, 5, 6) v MTA Exim. Nejvážnější z nich CVE-2023-42115 má CVSS 9.8. Na opravě chyb se pracuje.
Knihovna libvpx byla vydána ve verzi 1.13.1. Řešena je kritická bezpečnostní chyba CVE-2023-5217 (heap buffer overflow in vp8 encoding). Chyba je již opravena také v Chrome / Chromium 117.0.5938.132 a Firefoxu 118.0.1.
Balíček kmod s nástroji pro práci s linuxovými moduly byl vydán ve verzi 31. Nově umí modprobe zavést modul nacházející se v libovolném adresáři (# modprobe ./drivers/gpu/drm/i915/i915.ko).
Adventura Trüberbrook je na portále GOG.com zdarma, akce trvá do 2. října.
Sound Open Firmware, projekt Linux Foundation, open source audio DSP firmware a SDK, byl vydán ve verzi 2.7.0. Z novinek lze vypíchnout podporu platformy AMD Van Gogh.
Richard Stallman v den oslav 40. výročí GNU oznámil, že má rakovinu (YouTube).
DIY trackball Ploopy má novou variantu Adept, na rozdíl od předchozích používá 44mm kouli, má symetrický tvar a šest tlačítek, snímač zůstává PMW-3360, novinkou je použití Raspberry Pi Pico, na kterém běží firmware QMK s podporou grafické konfigurační aplikace VIA. Předobjednávky jsou otevřeny za ceny 80-105 CAD.
Probíhá Meta Connect 2023. Společnost Meta představuje své novinky v oblasti AI a virtuální, smíšené a rozšířené reality. Představeny byly nové chytré brýle Ray-Ban | Meta a headset Meta Quest 3.
Eben Upton oficiálně představil (YouTube) nové Raspberry Pi 5 (YouTube). Je více než 2x výkonnější než jeho předchůdce, model 4B.
Byl vydán (YouTube) Counter-Strike 2. Nativně také pro Linux. Jedná se o největší technologický skok v historii této populární herní série.
$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: