Dupa ce au fost adaugate mai multe date (randuri) intr-un tabel MySQL, se poate selecta anumite randuri si coloane cautand dupa un anumit termen sau cuvant. Pentru aceasta se foloseste comanda WHERE.

Cautare dupa valoarea coloanei

Intr-un tabel MySQL daca dorim sa fie selectate doar acele randuri in care o colana are o anumita valoare, se adauga in comanda SQL formula: WHERE `coloana`='valoare' , dupa cum se vede in urmatorul exemplu.
In acest exemplu vor fi selectate doar randurile din coloanele "col1" si "col2" unde "col1" are o anumita valoare fixa precizata.

<?php
// conecteaza la baza de date
$conn = new mysqli('localhost', 'root', 'pass', 'baza_date');

// verifica conexiunea
if (mysqli_connect_errno()) {
  exit('Connect failed: '. mysqli_connect_error());
}

$val = 'cuvant';           // Variabila ce contine valoarea pt. coloana cautata

// interogare sql SELECT 
$sql = "SELECT `col1`, `col2` FROM `tabel` WHERE `col1`='$val'"; 

// executa interogarea si retine datele returnate
$result = $conn->query($sql);

// daca $result contine cel putin un rand
if ($result->num_rows > 0) {
  // Parcurge si afiseaza randurile gasite
  while($row = $result->fetch_assoc()) {
    echo '<br />'. $row['col1']. ' - '. $row['col2'];
  }
}
else {
  echo '0 rezultate';
}

$conn->close();
?>
- "col1" si "col2" sunt coloanele din "tabel" care vrem sa fie selectate. Puteti adauga mai multe nume (separate prin virgula), sau pentru a selecta toate coloanele, se foloseste caracterul *

Pe langa formula "WERE" pot fi folosite si comenzile AND (si) sau OR (sau), pentru a efectua selecturi mai complexe, sau mai precise, cautand randurile in functie de valorile mai multor coloane.
- De exemplu, daca se doreste selectarea doar a randurilor in care avem "col1" cu valoarea "val1" si "col2" cu valoarea "val2"; randul selectat sa indeplineasca ambele conditii, se foloseste comanda SQL cu AND astfel:
$sql = "SELECT `col1`, `col2` FROM `tabel` WHERE `col1`='$val1' AND `col2`='$val2'";

- Daca se doreste selectarea randurilor in care avem "col1" cu valoarea "val1" sau "col2" cu valoarea "val2"; randul selectat sa indeplineasca una (oricare) din aceste conditii, se foloseste comanda SQL cu OR astfel:
$sql = "SELECT `col1`, `col2` FROM `tabel` WHERE `col1`='$val1' OR `col2`='$val2'";

Cautare dupa un anumit termen in rand

O alta selectare necesara este atunci cand se doreste cautarea randurilor care au in datele din coloana un anumit termen sau cuvant. Pentru aceasta se folosesc impreuna comenzile WHERE si LIKE.
Se adauga la comanda SQL formula: WHERE `coloana` LIKE 'termen'
De exemplu:

$sql = "SELECT `col1`, `col2` FROM `tabel` WHERE `col1` LIKE '$term'";
- Valoarea lui '$term' poate fi un cuvant sau fraza exacta, ori o parte dintr-un cuvant, in acest caz se foloseste si caracterul "%", astfel, pot fi obtinute urmatoarele 4 cazuri:
De obicei, termenul cautat este preluat dintr-un formular. Trebuie sa tineti cont de modul in care au fost adaugate datele in tabelul MySQL, daca au fost filtrate cu o functie, precum "mysql_real_escape_string()", cand se face selectul pentru cautare trebuie aplicata aceeasi functie termenului cautat.

- Mai jos puteti studia si folosi codul unui model de script, cu formular, pentru selectarea dintr-un tabel MySQL a randurilor in care se gaseste termenul transmis prin formular. Explicatiile detaliate sunt in codul scriptului.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="ro">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>Script cautare MySQL</title>
<meta name="description" content="Script cu formular pt cautare in tabel MySQL. Tutorial de la https://marplo.net" />
<meta name="keywords" content="script cautare" />
</head>
<body>

<form action="" method="post">
<input type="text" name="term" />
<input type="submit" name="submit" value="Cauta" />
</form>

<?php
// Script - Tutorial de la https://marplo.net

// Se verifica daca e primita valoare de la formular si are mai mult de 1 caracter
if (isset($_POST['term']) && strlen($_POST['term'])>1) {
  // Preia valoarea, eliminand posibile spatii exterioare
  $term = trim($_POST['term']);

  // conecteaza la baza de date
  $conn = new mysqli('localhost', 'root', 'pass', 'baza_date');

  // verifica conexiunea
  if (mysqli_connect_errno()) {
    exit('Connect failed: '. mysqli_connect_error());
  }

  // Filtreaza caracterele speciale ca sa poata fi utilizate in comanda SQL 
  $term = $conn->real_escape_string($term);

  // Se face selectarea si afisarea datelor returnate
  $sql = "SELECT * FROM `nume_tabel` WHERE `nume_coloana` LIKE '%$term%'"; 

  // executa interogarea si retine datele returnate
  $result = $conn->query($sql);

  // daca $result contine cel putin un rand
  if ($result->num_rows > 0) {
    // Parcurge si afiseaza randurile gasite
    while($row = $result->fetch_assoc()) {
      echo '<br />'. $row['col1']. ' - '. $row['col2'];
    }
  }
  else {
    echo '0 rezultate';
  }

  $conn->close();
}
?>
</body>
</html>

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce tip de <input> creaza o paleta de culori pentru selectare culoare?
type="text" type="color" type="date"
<input type="color" name="get_color" />
Care metoda CSS roteste elementul HTML la un anumit numar de grade?
scale() translate() rotate()
#some_id:hover {
  transform: rotate(60deg);
  -ms-transform: rotate(60deg);    /* IE 9 */
  -moz-transform: rotate(60deg);   /* Firefox */
}
Click pe functia care returneaza numarul cel mai mare.
pow() min() max()
var maxn = Math.max(8, 4, 88, 56);
alert(maxn);      // 88
Ce functie previne ca un fisier sa fie inclus mai mult de o data intr-o pagina?
include() include_once() require()
include_once("un_fisier.php");
Care este traducerea corecta pentru: "Ahead of time"?
Peste timp La timp Inainte de vreme
Most people arrived ahead of time.
- Cei mai multi oameni au sosit inainte de vreme (prea devreme).
Indicati traducerea corecta a cuvantului "buenĂ­simo"
mai bun mai putin bun extrem de bun
Este fruto es buenĂ­simo.
- Acest fruct este extrem /nemaipomenit de bun.
Cautare in tabel MySQL

Last accessed pages

  1. Sufixele -ful, -less si -ness - ful, less and ness suffixes (6612)
  2. Curs PHP MySQL, Tutoriale si Scripturi PHP (14202)
  3. Viitor simplu si continuu - Future Tense Simple and Continuous (22636)
  4. Curs si Tutoriale JavaScript (15184)
  5. Conditional IF - Exercitii si teste engleza incepatori (7829)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (2215)
  2. Curs HTML gratuit Tutoriale HTML5 (1594)
  3. Curs si Tutoriale JavaScript (1571)
  4. Curs PHP MySQL, Tutoriale si Scripturi PHP (1525)
  5. Curs CSS Online Tutoriale CSS3 (1401)