Artikel ini menjelaskan bagaimana cara mengambil data query dalam database mysql menggunakan command prompt dan menggunakan Script PHP.
Artikel ini menjelaskan bagaimana cara mengambil data query dalam database mysql menggunakan command prompt dan menggunakan Script PHP.
Perintah SQL SELECT digunakan untuk mengambil data dari database MySQL. Anda dapat menggunakan perintah ini di mysql> meminta maupun di script seperti PHP.
Sintaks :
Berikut adalah sintaks SQL generik dari perintah SELECT untuk mengambil data dari tabel MySQL:
SELECT field1, field2,...fieldN table_name1, table_name2... [WHERE Clause] [OFFSET M ][LIMIT N]
- Anda dapat menggunakan satu atau lebih tabel dipisahkan dengan koma dalam memasukkan berbagai keadaan memakai klausa MANA, namun klausa WHERE adalah bagian opsional perintah SELECT.Anda dapat mengambil satu atau lebih field dalam perintah SELECT tunggal.Anda dapat memilih bintang (*) di tempat field. Pada hal ini, SELECT akan mengembalikan semua field.Anda dapat menentukan keadaan menggunakan klausa WHERE.Anda dapat memilih offset menggunakan OFFSET dari mana SELECT akan mulai catatan kembali. Secara default offset ialah nol.Anda dapat membatasi jumlah pengembalian menggunakan atribut LIMIT.
Mengambil Data dari Command Prompt:
ini akan menggunakan perintah SQL SELECT untuk mengambil data dari tabel tutorial_tbl
Contoh:
Contoh berikut akan mengembalikan semua catatan dari tabel tutorial_tbl:
root@host# mysql -u root -p password; Enter password:******* mysql> use TUTORIALS; Database changed mysql> SELECT * from tutorials_tbl +-------------+----------------+-----------------+-----------------+ | tutorial_id | tutorial_title | tutorial_author | submission_date | +-------------+----------------+-----------------+-----------------+ | 1 | Learn PHP | John Poul | 2007-05-21 | | 2 | Learn MySQL | Abdul S | 2007-05-21 | | 3 | JAVA Tutorial | Sanjay | 2007-05-21 | +-------------+----------------+-----------------+-----------------+ 3 rows in set (0.01 sec) mysql>
Mengambil Data Menggunakan PHP Script:
Anda dapat menggunakan yang sama perintah SQL SELECT ke dalam fungsi PHP mysql_query(). Fungsi ini digunakan untuk mengeksekusi perintah SQL dan kemudian lain fungsi PHP mysql_fetch_array() dapat digunakan untuk mengambil semua data yang dipilih. Fungsi ini mengembalikan baris sebagai array asosiatif, array numerik, atau keduanya. Fungsi ini mengembalikan FALSE jika tidak ada baris lagi.
Berikut ini adalah contoh sederhana untuk mengambil catatan dari meja tutorials_tbl.
Contoh:
Coba contoh berikut untuk menampilkan semua record dari tabel tutorial_tbl.
<?php $dbhost = 'localhost:3036'; $dbuser = 'root'; $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn ); if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Tutorial ID :{$row['tutorial_id']} <br> ". "Title: {$row['tutorial_title']} <br> ". "Author: {$row['tutorial_author']} <br> ". "Submission Date : {$row['submission_date']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn); ?>
Isi dari baris ditugaskan ke $row variabel dan nilai-nilai berturut-turut kemudian dicetak.
CATATAN: Selalu ingat untuk menempatkan kurung keriting ketika Anda ingin memasukkan nilai array langsung ke string.
Dalam contoh di atas, MYSQL_ASSOC konstan digunakan sebagai argumen kedua untuk fungsi PHP mysql_fetch_array (), sehingga ia mengembalikan baris sebagai array asosiatif. Dengan array asosiatif Anda dapat mengakses lapangan dengan menggunakan nama mereka daripada menggunakan indeks.
PHP menyediakan fungsi lain yang disebut mysql_fetch_assoc (), yang juga mengembalikan baris sebagai array asosiatif.
Contoh :
Coba contoh berikut untuk menampilkan semua record dari tabel tutorial tbl menggunakan fungsi mysql_fetch_assoc() .
<?php $dbhost = 'localhost:3036'; $dbuser = 'root'; $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn ); if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_assoc($retval)) { echo "Tutorial ID :{$row['tutorial_id']} <br> ". "Title: {$row['tutorial_title']} <br> ". "Author: {$row['tutorial_author']} <br> ". "Submission Date : {$row['submission_date']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn); ?>
Anda juga dapat menggunakan MYSQL_NUM konstan sebagai argumen kedua untuk fungsi PHP mysql_fetch_array(). Hal ini akan menyebabkan fungsi untuk mengembalikan array dengan indeks numerik.
Contoh:
Coba contoh berikut untuk menampilkan semua catatan dari tutorial meja tbl menggunakan argumen MYSQL_NUM.
<?php $dbhost = 'localhost:3036'; $dbuser = 'root'; $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn ); if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_NUM)) { echo "Tutorial ID :{$row[0]} <br> ". "Title: {$row[1]} <br> ". "Author: {$row[2]} <br> ". "Submission Date : {$row[3]} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn); ?>
Semua di atas tiga contoh akan menghasilkan hasil yang sama.
Melepaskan Memory:
Ini adalah praktik yang baik untuk melepaskan memori kursor pada akhir setiap pernyataan SELECT. Hal ini dapat dilakukan dengan menggunakan fungsi PHP mysql_free_result(). Berikut adalah contoh untuk menunjukkan bagaimana itu harus digunakan.
<?php $dbhost = 'localhost:3036'; $dbuser = 'root'; $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT tutorial_id, tutorial_title, tutorial_author, submission_date FROM tutorials_tbl'; mysql_select_db('TUTORIALS'); $retval = mysql_query( $sql, $conn ); if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_NUM)) { echo "Tutorial ID :{$row[0]} <br> ". "Title: {$row[1]} <br> ". "Author: {$row[2]} <br> ". "Submission Date : {$row[3]} <br> ". "--------------------------------<br>"; } mysql_free_result($retval); echo "Fetched data successfully\n"; mysql_close($conn); ?>
COMMENTS