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 HTML5 defineste un text marcat, evidentiat?
<mark> <embed> <span>
<p>Cursuri graruite: <mark>MarPlo.net</mark> , jocuri, anime.</p>
Ce pseudo-clasa CSS defineste un stil la element cand mouse-ul e deasupra lui?
:focus :hover :active
a:hover {
  font-weight: bold;
  color: #00da01;
}
Clic pe functia ce returneaza un sir cu un numar rotunjit la x decimale.
toPrecision(x) toFixed(x) floor(x)
var num = 12.34567;
num = num.toFixed(2);
alert(num);       // 12.35
Indicati functia PHP care adauga continutul unui fisier intr-un array.
[) file() readfile()
$arr = file("a_file.txt", FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
var_export($arr);
Clic pe raspunsul potrivit la intrebarea: "What time is it?"
On the 7th of July 1996 It is a quarter to 5. Nice weather.
What time is it? It is a quarter to 5.
- Cat este ora? E 5 fara un sfert.
Indicati raspunsul potrivit la intrebarea: "¿Qué hora es?"
Hace buen tiempo. En el 7 de julio de 1996 Son las tres menos cuarto.
¿Qué hora es? Son las tres menos cuarto.
- Cat este ora? E 3 fara un sfert.
Cautare in tabel MySQL

Last accessed pages

  1. Alphabet and Pronunciation - Alfabetul si pronuntia in limba engleza (40764)
  2. Curs CSS Online Tutoriale CSS3 (40900)
  3. Curs PHP MySQL, Tutoriale si Scripturi PHP (48911)
  4. Curs si Tutoriale Ajax (35731)
  5. Creare Foi de Stil (1631)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (1585)
  2. Curs HTML gratuit Tutoriale HTML5 (1189)
  3. Curs PHP MySQL, Tutoriale si Scripturi PHP (1141)
  4. Curs si Tutoriale Ajax (1054)
  5. Curs si Tutoriale JavaScript (1048)