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
Care tag adauga rand nou in paragraf?
<b> <br> <p>
Prima linie ...<br>
Alta linie...
Ce proprietate CSS seteaza spatiu dintre litere?
text-size word-spacing letter-spacing
#id {
  letter-spacing: 2px;
}
Ce functie obtine accesul la un element HTML cu un anumit ID?
getElementById() getElementsByTagName() createElement()
var elm = document.getElementById("theID");
var content = elm.innerHTML;
alert(content);
Clic pe instructiunea "echo" utilizata corect.
echo "CoursesWeb.net" echo "CoursesWeb.net"; echo ""CoursesWeb.net";
echo "Adresa URL: http://CoursesWeb.net";
Care din urmatoarele expresii cu "paint" (a picta) se foloseste pentru forma Negativa?
will paint not paint have painted
She does not paint that landscape.
- Ea nu picteaza acel peisaj.
Care din urmatoarele expresii cu "cantar" (a canta) se foloseste pentru propozitie Negativa?
ir a cantar cantaba no cantar
Ella no canta esa canciĆ³n.
- Ea nu canta acel cantec.
Cautare in tabel MySQL

Last accessed pages

  1. Viitor perfect si Viitorul perfect continuu - Future perfect and Continuous (8991)
  2. Trecutul simplu si continuu - Past Tense Simple and Continuous (32036)
  3. Functii pentru Data si Timp (256)
  4. Instructiuni conditionale if else (574)
  5. PHP MySQL - UPDATE (281)

Popular pages this month

  1. Gramatica limbii engleze - Prezentare Generala (3020)
  2. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (1010)
  3. Gramatica limbii spaniole. Indrumator si prezentare generala (834)
  4. Alphabet and Pronunciation - Alfabetul si pronuntia in limba engleza (726)
  5. Prezentul simplu si continuu - Present Tense Simple and Continuous (672)