Curs Php-mysql

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 tag adauga imagine in pagina web?
<div> <img> <span>
<img src="http://coursesweb.net/imgs/webcourses.gif" width="191" height="63" alt="Courses-Web" />
Care din aceste coduri CSS afiseaza textul inclinat?
font-style: italic; text-decoration: underline; font-weight: 500;
#id {
  font-style: italic;
}
Clic pe functia jQuery care ascunde animat un element HTML.
click() hide() show()
$(document).ready(function() {
  $(".a_class").click(function(){ $(this).hide("slow"); });
});
Clic pe functia definita corect in PHP.
fname function() {} function fname() {} function $fname() {};
function fname($a, $b) {
  echo $a * $b;
}
Indicati forma pentru Prezent Perfect Continuu a verbului "to walk" (a merge).
have walked have been walking be walking
I have been walking for 5 hours.
- Merg pe jos de 5 ore.
Indicati Trecutul Nedefinit pentru verbul "ser" (a fi) la forma Yo.
será sería fui
Yo fui entrenador.
- Am fost antrenor.
Cautare in tabel MySQL

Last accessed pages

  1. Conditional IF in Limba Engleza - Fraze Conditionale (120725)
  2. Mini vocabular Englez-Roman (6269)
  3. Scriere cod CSS (5501)
  4. Curs CSS Online Tutoriale CSS3 (116727)
  5. Pronume - Exercitii si teste engleza incepatori (15019)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (1247)
  2. Curs HTML gratuit Tutoriale HTML5 (962)
  3. Coduri pt culori (715)
  4. Creare si editare pagini HTML (567)
  5. Conditional IF in Limba Engleza - Fraze Conditionale (521)
Chat
Discuta sau lasa un mesaj pt. ceilalti utilizatori
Full screenInchide