Diskuze: Jak selectovat specifické jedno pole v MySQL
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 5 zpráv z 5.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj,
tak za mě to je něco ve smyslu:
$zkus = Db::query("SELECT id FROM tabulka WHERE jmeno_uzivatele=? AND drevorubec=?","jmeno",1);
if($zkus){
//ANO, proveď
}
samozřejmě se to dá zkrátit a dát dotaz do IF.
mysql_query se uz leta nepouziva, protoze nema prepared statement, viz ten sql dotaz od JP s temi otazniky. V mysql by to vypadalo takto:
https://www.php.net/manual/en/function.mysql-real-escape-string.php
// Query
$query = sprintf("SELECT * FROM users WHERE user='%s' AND password='%s'",
mysql_real_escape_string($user),
mysql_real_escape_string($password));
// polackovo reseni
$query = "SELECT `id` FROM `tabulka` WHERE `jmeno_uzivatele`=? AND `drevorubec`=?";
$result = Db::query($query, "jmeno uzivatele", 1);
// vysledek: " SELECT `id` FROM `tabulka` WHERE `jmeno_uzivatele`='jmeno uzivatele' AND `drevorubec`=1 ";
// reseni podle dokumentace php.net - online, example 1 u funkce mysql-real-escape-string
$query = "SELECT * FROM `users` WHERE `user`='%s' AND `password`='%s'";
$query = sprintf($query,
mysql_real_escape_string($user), //"jmeno uzivatele",
mysql_real_escape_string($password));"heslo",
// vysledek: " SELECT * FROM `users` WHERE `user`='jmeno uzivatele' AND `password`='heslo' "
$result = mysql_query($query);
Neni mozne, ze by sis prehledl na prave strane v dokumentaci tuto funkci.
Ledaze by ses tam ani nepodival a nezajimalo te, jake funkce mysql tam ma. Nebo
aspon zkusit googlovat reseni.
sprintf - je funkce, ktera doplnuje text do stringu, podle zadaneho pravidla,
treba %s je formatovani jako string, opet viz dokumentace php.net, tam je to
krasne popsane. Ale muzes pouzit i str_replace nebo preg_replace. Str_replace by
melo byt pro tuto operaci rychlejsi. Kdyby slo o nahrazovani 1 znaku, tak je
rychlejsi strtr.
Zobrazeno 5 zpráv z 5.