Diskuze: SQL dotaz pro vyhledání slova z db tabulky
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 12 zpráv z 12.
//= 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,
teoreticky by to mělo jít tímto způsobem
SELECT id, f_nazev AS nazev FROM tablice WHERE f_nazev LIKE '%$searchQuery%' AND distributor = 'B'
S tím druhým případem nevim, proč to nefunguje. Pokud nikdo neporadí přede mnou, tak až skončí fotbal, podívám se na to
Ahoj, tento zápis jsem zkoušela, ale hlásilo mi to 0 výsledků, přestože v tabulce tato možnost se vyskystuje.
Michal Štěpánek: "id" to tahá automaticky číslo řádku, na kterém se nazev vyskytuje. Ale i tak jsem zkusila "id" z výpisu odstranit, aby to vypisovalo jen proměnnou nazev a bez uspechu.
Ze by byl problem s cyklem pro vypis?
// include_once("connect_to_mysql.php");
$query = mysql_query($sqlCommand) or die(mysql_error());
$count = mysql_num_rows($query);
if($count > 1){
$search_output .= "<hr />$count results for <strong>$searchquery</strong><hr />$sqlCommand<hr />";
while($row = mysql_fetch_array($query)){
$id = $row["id"];
$name = $row["nazev"];
$search_output .= "Item ID: $id - $nazev<br />";
} // close while
} else {
$search_output = "<hr />0 results for <strong>$searchquery</strong><hr />$sqlCommand";
}
id to netahá automaticky číslo řádků, id musí být sloupec typu integer s vlastností AUTO_INCREMENT.
Tabulku mám vytvořenou na základě příkazu, kde mám i to id zapsáno
$sqlCommand="CREATE TABLE tablice (
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
rok CHAR(10),
distributor CHAR(10),
f_nazev CHAR(10),
FULLTEXT (typ,distributor,f_nazev)
) ENGINE=MyISAM";
Tabulka je úspěšné vytvořena a i naplněna hodnotami.
Nemá být místo tohoto
$name = $row["nazev"];
toto
$name = $row["f_nazev"];
?
V om případě zkus ještě poupravit ten dotaz
místo
WHERE f_nazev like..
zkus dát
... WHERE nazev like...
a to nemělo být jako odpověď tobě, sorry...
Zkus přejmenovat f_name za fname.
První situace
$sql = "
SELECT id, fname AS name
FROM tablice
WHERE fname LIKE('%$string%') AND distributor = $string2
";
Druhá situace
$sql = "
SELECT id, fname AS name
FROM tablica
WHERE fname LIKE('%$string%')
";
Začni pomalu s PDO nebo mysqli, takhle je to nebezpečné.
V pohodě, on má v tabulce f_name, ale tím AS přejmenuje výstupní proměnnou.
Zobrazeno 12 zpráv z 12.