PHP MySQL - SELECT, ORDER BY

Cand baza de date are cateva inregistrari in ea, puteti prelua informatia stocata, folosind comanda SELECT.
O interogare SELECT returneaza randuri selectate de la unul sau mai multe tabele.

  - Sintaxa:
SELECT nume_coloana/e FROM nume_tabel
- "nume_coloana/e" - este numele coloanei sau coloanelor care vor fi selectate.

Pentru a selecta mai multe coloane, adaugatile separate prin virgula:
                SELECT coloana1, coloana2, coloana3 FROM nume_tabel

Pentru a selecta toate coloanele, punti un asterisc (*):
                SELECT * FROM nume_tabel

Ca sa fie trimisa comanda SQL la baza de date MySQL si pentru a prelua datele selectate, se foloseste metoda query() a obiectului mysqli.
Cand este folosita cu interogari SELECT, aceasta metoda returneaza un obiect care contine randurile de date, sau False in caz de eroare.
Pentru a parcurge datele returnate si sa obtineti cate un rand din ele, puteti folosi metoda fetch_assoc.
Metoda fetch_assoc() returneaza un array asociativ ce contine randurile preluate, cheile din array reprezinta numele coloanelor.
Cu o bucla while() puteti prelua informatiile din fiecare rand stocat in acel array.
Pentru a afla numarul de randuri returnat de o interogare SELECT, se foloseste proprietatea num_rows, aplicata la obiectul rezultat.

  - Urmatorul exemplu selecteza si afiseaza datele stocate in coloanele "id", "name" si"pass" din tabelul "users".
<?php
// conecteaza la baza de date "tests" 
$conn = new mysqli('localhost', 'root', 'pass', 'tests');

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

// interogare sql SELECT 
$sql = "SELECT `id`, `name`, `pass` FROM `users`"; 

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

// daca $result contine cel putin un rand
if ($result->num_rows > 0) {
  // afiseaza datele din fiecare rand din $result
  while($row = $result->fetch_assoc()) {
    echo '<br /> id: '. $row['id']. ' - name: '. $row['name']. ' - pass: '. $row['pass'];
  }
}
else {
  echo '0 rezultate';
}

$conn->close();
?>
- Acest exemplu stocheaza datele (obiectul rezultat) returnate de metoda query() in variabila $result , foloseste proprietatea "num_rows" sa verifice daca $result contine cel putin un rand. Apoi, cu bucla while() trece prin toate inregistrarie din obiecul rezultat, folosind metoda "fetch_assoc()" pentru a retine datele din fiecare rand intr-un Array in variabila $row.
Fiecare apelare a fetch_assoc() returneaza urmatorul rand in setul de rezultate, pana cand nu mai sunt, si returneaza False.
Pentru a accesa valorile din fiecare rand, se foloseste variabila PHP $row si cheia cu numele coloanei ($row['id'], ...).
Codul de mai sus va afisa:
id: 1 - name: Marius - pass: faith
id: 2 - name: MarPlo - pass: peace
id: 3 - name: I_AM - pass: love
id: 4 - name: PloMar - pass: love_light

Asterisc (*) poate fi folosit pentru a selecta toate coloanele: "SELECT * FROM nume_tabel", dar este mai bine sa specificati doar coloanele care vreti sa fie selectate, deoarece procesul de selectare poate fi mai rapid.

Optiunea LIMIT

Cu optiunea LIMIT puteti sa determinati numarul de inregistrari pe care MySQL le va returna:
  - Sintaxa:
SELECT nume_coloana/e FROM nume_tabel LIMIT skip_nr, ret_nr
"skip_nr" este optional, ii spune bazei de date cate randuri sa sara din rezultate.
"ret_nr" seteaza numarul maxim de inregistrari ce vor fi returnate.
  - Exemplu:
<?php
// conecteaza la baza de date "tests"
$conn = new mysqli('localhost', 'root', 'pass', 'tests');

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

// interogare sql SELECT 
$sql = "SELECT `id`, `name`, `pass` FROM `users` LIMIT 2"; 

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

// daca $result contine cel putin un rand
if ($result->num_rows > 0) {
  // afiseaza datele din fiecare rand din $result
  while($row = $result->fetch_assoc()) {
    echo '<br /> id: '. $row['id']. ' - name: '. $row['name']. ' - pass: '. $row['pass'];
  }
}
else {
  echo '0 rezultate';
}

$conn->close();
?>
Optiunea "LIMIT 2" spune MySQL sa returneze primele 2 randuri din rezultat.
Acest exemplu va afisa:
id: 1 - name: Marius - pass: faith
id: 2 - name: MarPlo - pass: peace

ORDER BY

ORDER BY specifica ordinea de sortare a resultatelor.
  - Sintaxa:
SELECT nume_coloana/e FROM nume_tabel ORDER BY nume_col ASC|DESC
"nume_col" poate fi o singura coloana, o lista de coloane separate prin virgula, sau o expresie ca RAND(), pentru a obtine o ordine aleatorie.
Cand se ordoneaza dupa mai mult de o coloana, a doua coloana e folosita in sortare doar daca valorile din prima coloana sunt egale.
Ordinea de sortare standard este ascendenta (ASC) (a–z, 0–9), iar optiunea ASC poate fi omisa. DESC (descrescator) inverseaza ordinea.
  - Exemplu:
<?php
// conecteaza la baza de date "tests" 
$conn = new mysqli('localhost', 'root', 'pass', 'tests');

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

// interogarea sql SELECT 
$sql = "SELECT `id`, `name`, `pass` FROM `users` ORDER BY `name`"; 

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

// daca $result contine cel putin un rand
if ($result->num_rows > 0) {
  // afiseaza datele din fiecare rand din $result
  while($row = $result->fetch_assoc()) {
    echo '<br /> id: '. $row['id']. ' - name: '. $row['name']. ' - pass: '. $row['pass'];
  }
}
else {
  echo '0 results';
}

$conn->close();
?>
- Acest cod selecteaza toate datele stocate in tabelul "users" , si sorteaza rezultatul in ordine alfabetica dupa coloana "name".
Exemplul de mai sus va afisa:
id: 3 - name: I_AM - pass: love
id: 1 - name: Marius - pass: faith
id: 2 - name: MarPlo - pass: peace
id: 4 - name: PloMar - pass: love_light

• Puteti folosi ORDER BY cu optiunea LIMIT.
                Exemplu:       "SELECT `id`, `name`, `pass` FROM `users` ORDER BY `name` LIMIT 2"

• Daca vreti sa ignore randurile duplicate (care au aceleasi valori), se foloseste optiunea DISTINCT:
               
SELECT DISTINCT nume_coloana/e FROM nume_tabel

- Se pot de asemenea selecta coloane din tabele diferite, in aceeasi interogare SQL, vedeti tutorialul Select in doua tabele MySQL.
PHP MySQL - INSERT ... <<-- Anterior --- Urmator -->> PHP MySQL - WHERE ...

Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce tag se foloseste pentru a adauga liste in elemente <ul> si <ol>?
<dt> <dd> <li>
<ul>
 <li>http://coursesweb.net/html/</li>
 <li>http://www.marplo.net/html/</li>
</ul>
Care valoare a proprietatii "display" seteaza elementul ca tip bloc si afiseaza un punct in fata?
block list-item inline-block
.some_class {
  display: list-item;
}
Care instructiune JavaScript transforma un obiect in sir JSON.
JSON.parse() JSON.stringify eval()
var obj = {
 "courses": ["php", "javascript", "ajax"]
};
var jsonstr = JSON.stringify(obj);
alert(jsonstr);    // {"courses":["php","javascript","ajax"]}
Indicati clasa PHP folosita pentru a lucra cu elemente HTML si XML in PHP.
stdClass PDO DOMDocument
$strhtml = '<body><div id="dv1">CoursesWeb.net</div></body>';
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);
$elm = $dochtml->getElementById("dv1");
echo $elm->nodeValue;    // CoursesWeb.net
Indicati forma de Prezent Continuu a verbului "to live" (a trai /a locui)
lived living liveing
I`m living here.
- Traiesc /Locuiesc aici.
Care este forma de Gerunziu (sau Participiu Prezent) a verbului "vivir" (a trai /a locui)?
vivió vivido viviendo
Estoy viviendo aquí.
- Traiesc /Locuiesc aici.
PHP MySQL - SELECT, ORDER BY - Tutoriale PHP