詳解用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將開始返回記錄的偏移量。默認(rèn)情況下,偏移量為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命令進(jìn)入PHP函數(shù)mysql_query()。這個函數(shù)是用來執(zhí)行SQL命令后,另一個PHP函數(shù)mysql_fetch_array()可以用來獲取所有選定的數(shù)據(jù)。這個函數(shù)返回的行作為一個關(guān)聯(lián)數(shù)組/數(shù)字?jǐn)?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,行中的值,然后打印。
注: 一定要記住,當(dāng)要插入到一個字符串?dāng)?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()。這將導(dǎo)致該函數(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語句釋放游標(biāo)內(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ù)的同時可以編寫復(fù)雜的SQL,只要喜歡。程序?qū)⒈3峙c上述相同。
相關(guān)文章
SQL實現(xiàn)LeetCode(183.從未下單訂購的顧客)
這篇文章主要介紹了SQL實現(xiàn)LeetCode(182.從未下單訂購的顧客),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
真的了解MySQL中的binlog和redolog區(qū)別
MySQL的binlog和redolog都是用于記錄數(shù)據(jù)庫操作的日志文件,但是它們有不同的作用和特點,今天給大家分享MySQL的binlog和redolog區(qū)別,感興趣的朋友一起看看吧2023-11-11

