Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.
Byla vydána nová verze 2.45.0 distribuovaného systému správy verzí Git. Přispělo 96 vývojářů, z toho 38 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání. Vypíchnout lze počáteční podporu repozitářů, ve kterých lze používat SHA-1 i SHA-256.
Před 25 lety, ve čtvrtek 29. dubna 1999, byla spuštěna služba "Úschovna".
Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
Byla vydána verze 5.30 dnes již open source operačního systému RISC OS (Wikipedie).
V aktuálním příspěvku na blogu počítačové hry Factorio (Wikipedie) se vývojář s přezývkou raiguard rozepsal o podpoře Linuxu. Rozebírá problémy a výzvy jako přechod linuxových distribucí z X11 na Wayland, dekorace oken na straně klienta a GNOME, změna velikosti okna ve správci oken Sway, …
Rakudo (Wikipedie), tj. překladač programovacího jazyka Raku (Wikipedie), byl vydán ve verzi #171 (2024.04). Programovací jazyk Raku byl dříve znám pod názvem Perl 6.
Společnost Epic Games vydala verzi 5.4 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.
try { $sql = 'INSERT INTO `users` (id, mail, pass, name) VALUES (:id, :mail, :pass, :name)'; $stmt = $pdo->prepare($sql); $stmt->execute(array(':id' => null, ':mail' => 'foo@bar.ltd', ':pass' => 'secret', ':name' => 'ja' ); } catch (PDOException $e) { echo $e->getMessage(); }
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTIONBez toho výjimky nefungují. Máš tam zbytečný sloupec
id
.
$sql = 'INSERT INTO `users` (mail, pass, name) VALUES (:mail, :pass, :name)';
Možná sis nezapnulNemám to přesně jako ty ale mám to nastaveno taktoPDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTIONBez toho výjimky nefungují.
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
Máš tam zbytečný sloupec id
.
proč? sloupec id opravdu v db mám
je lepší používat tohle
$sql = 'INSERT INTO `users` (`id`, `mail`, `pass`, `name`) VALUES (:`id`, :`mail`, :`pass`, :`name`)';nebo tohle
$sql = 'INSERT INTO `users` (`id`, `mail`, `pass`, `name`) VALUES (?, ?, ?, ?)';Díky
$stmt->execute
. Když jsem ji doplnil, tak mi to funguje.
Jak jsi založil tabulku?
Stejně mi není jasné, proč ti to nevyhazuje chybu na chybějící pravou závorku při volání $stmt->execute
. Když jsem ji doplnil, tak mi to funguje.
To byl jenom úklep při vkládání kódu..
Jak jsi založil tabulku?Jak to myslíš?
Jakým SQL dotazem. Mně ten příklad funguje, tobě ne. To znamená, že se nejspíš naše tabulky nějak liší. Založil jsem ji takto:Jak jsi založil tabulku?Jak to myslíš?
CREATE TABLE users(id integer primary key auto_increment, mail varchar(255), pass varchar(24), name varchar(24));
$array = array('mail' => 'foo@bar.ltd', 'pass' => 'secret', 'name' => 'ja'); $sql = 'INSERT INTO `users` ('.$array.') VALUES ('.$array.')'; $stmt = $pdo->prepare($sql); $stmt->execute($array);
$data = array('mail' => 'foo@bar.ltd', 'pass' => 'secret', 'name' => 'ja'); $sql = "INSERT INTO `users` (" . implode(', ', array_keys($data)) . ") VALUES (" . implode(', ', array_fill(0, sizeof($data), "?")) . ")"; $stmt = $pdo->prepare($sql); $stmt->execute(array_values($data));ale nepoužívám to.
function save($pdo, $table, $columns) { $before = false; $after = false; $array = array(); foreach ($columns as $key => $value) { if(end($array) == $key) { $before .= "`$key`"; $after .= ":`$key`"; } else { $before .= "`$key`,"; $after .= ":`$key`,"; } $array[] = "$key => $value"; } $sql = "INSERT INTO `$table` ($before) VALUES ($after)"; $stmt = $pdo->prepare($sql); $stmt->execute($array); }
Tiskni Sdílej: