詳解用SELECT命令在MySQL執(zhí)行查詢操作的教程
SQL SELECT命令被用來獲取數(shù)據(jù)從MySQL數(shù)據(jù)庫??梢允褂么嗣钤趍ysql>提示符下或使用腳本,如PHP。
語法:
下面是通用的SQL SELECT命令的語法來從MySQL表提取數(shù)據(jù):
SELECT field1, field2,...fieldN table_name1, table_name2... [WHERE Clause] [OFFSET M ][LIMIT N]
- 可以使用一個或多個以逗號分隔的表,包括各種使用WHERE子句條件。但是WHERE子句的SELECT命令是一個可選部分。
- 可以在一個單一的SELECT命令讀取一個或多個字段。
- 可以指定星號(*)的字段的地方。在這種情況下,SELECT將返回所有的字段
- 可以使用WHERE子句指定任何條件。
- 可以指定偏移用SELECT將開始返回記錄的偏移量。默認情況下,偏移量為0
- 可以限制返回的使用LIMIT屬性的數(shù)量。
從命令提示符獲取數(shù)據(jù):
這將使用SQL SELECT命令來從MySQL表tutorials_tbl獲取數(shù)據(jù)
例子:
下面的例子將返回所有記錄tutorials_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>
使用PHP腳本獲取數(shù)據(jù):
您可以使用相同的SQL SELECT命令進入PHP函數(shù)mysql_query()。這個函數(shù)是用來執(zhí)行SQL命令后,另一個PHP函數(shù)mysql_fetch_array()可以用來獲取所有選定的數(shù)據(jù)。這個函數(shù)返回的行作為一個關(guān)聯(lián)數(shù)組/數(shù)字數(shù)組或兩者。如果沒有更多的行這個函數(shù)返回FALSE。
下面是一個簡單的例子,獲取記錄tutorials_tbl表。
例子:
試試下面的例子顯示tutorials_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); ?>
這些行的內(nèi)容被分配到變量$row,行中的值,然后打印。
注: 一定要記住,當要插入到一個字符串數(shù)組的值直接用花括號。
在上面的例子中不斷MYSQL_ASSOC作為PHP函數(shù)mysql_fetch_array()第二個參數(shù),以便它返回一個關(guān)聯(lián)數(shù)組的行為。一個關(guān)聯(lián)數(shù)組,可以使用他們的名字,而不是使用索引訪問字段。
PHP提供了另一種稱為mysql_fetch_assoc()函數(shù)也返回該行作為關(guān)聯(lián)數(shù)組。
實例:
試試下面的例子顯示從tutorial_tbl表的所有記錄,使用mysql_fetch_assoc()函數(shù)。
<?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); ?>
也可以使用常量MYSQL_NUM,作為第二個參數(shù)的PHP函數(shù)mysql_fetch_array()。這將導致該函數(shù)返回一個數(shù)字索引的數(shù)組。
實例:
試試下面的例子顯示使用MYSQL_NUM參數(shù)tutorials_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_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); ?>
所有上述三個例子,將產(chǎn)生相同的結(jié)果。
釋放內(nèi)存:
它是一種很好的做法,在每一個SELECT語句釋放游標內(nèi)存。這可以通過使用PHP函數(shù)了mysql_free_result()。下面的例子來說明它是如何被使用的。
實例:
試試下面的例子
<?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); ?>
在獲取數(shù)據(jù)的同時可以編寫復雜的SQL,只要喜歡。程序?qū)⒈3峙c上述相同。
相關(guān)文章
SQL實現(xiàn)LeetCode(183.從未下單訂購的顧客)
這篇文章主要介紹了SQL實現(xiàn)LeetCode(182.從未下單訂購的顧客),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08真的了解MySQL中的binlog和redolog區(qū)別
MySQL的binlog和redolog都是用于記錄數(shù)據(jù)庫操作的日志文件,但是它們有不同的作用和特點,今天給大家分享MySQL的binlog和redolog區(qū)別,感興趣的朋友一起看看吧2023-11-11