MySQL SELECT 语句:查询数据

MySQL 数据库使用SQL SELECT语句来查询数据。

我们可以通过 mysql> 命令窗口在数据库中查询数据,或者通过PHP脚本来查询数据。

 

1. MySQL SELECT 语句的语法

SELECT column_name,column_name
FROM table_name
[WHERE Clause]
[LIMIT N][ OFFSET M]
  • 查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件。
  • SELECT 命令可以读取一条或者多条记录。
  • 你可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
  • 你可以使用 WHERE 语句来包含任何条件。
  • 你可以使用 LIMIT 属性来设定返回的记录数。
  • 你可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认情况下偏移量为0。

 

2. 通过命令窗口获取数据

以下范例我们将通过 SQL SELECT 命令来获取 article 表的所有记录:

SELECT * FROM article;

 

3. 使用PHP脚本来获取数据

使用 PHP 函数的 mysqli_query() 命令来获取数据。

该函数用于执行 SQL 命令,然后通过 PHP 函数 mysqli_fetch_array() 来使用或输出所有查询的数据。

mysqli_fetch_array() 函数从结果集中取得一行作为关联数组,或数字数组,或二者兼有 返回根据从结果集取得的行生成的数组,如果没有更多行则返回 false。

以下范例为从数据表 article 中读取所有记录。

MySQL 范例

<?php $dbhost = ' localhost ' ; // mysql服务器主机地址 $dbuser = ' root ' ; // mysql用户名 $dbpass = ' 123456 ' ; // mysql用户名密码 $conn = mysqli_connect ( $dbhost , $dbuser , $dbpass ) ; if ( ! $conn ) { die ( ' 连接失败: ' . mysqli_error ( $conn ) ) ; } // 设置编码,防止中文乱码 mysqli_query ( $conn , " set names utf8 " ) ; $sql = ' SELECT id, title, author, submission_date FROM article ' ; mysqli_select_db ( $conn , ' CodeBaoku ' ) ; $retval = mysqli_query ( $conn , $sql ) ; if ( ! $retval ) { die ( ' 无法读取数据: ' . mysqli_error ( $conn ) ) ; } echo ' <h2>编程宝库 mysqli_fetch_array 测试</h2> ' ; echo ' <table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr> ' ; while ( $row = mysqli_fetch_array ( $retval , MYSQLI_ASSOC ) ) { echo " <tr><td> {$row['id']} </td> " . " <td> {$row['title']} </td> " . " <td> {$row['author']} </td> " . " <td> {$row['submission_date']} </td> " . " </tr> " ; } echo ' </table> ' ; mysqli_close ( $conn ) ; ?>

以上范例中,读取的每行记录赋值给变量 $row,然后再打印出每个值。

注意:记住如果你需要在字符串中使用变量,请将变量置于花括号。

 

4. 内存释放

在我们执行完 SELECT 语句后,释放游标内存是一个很好的习惯。

可以通过 PHP 函数 mysqli_free_result() 来实现内存的释放。

以下范例演示了该函数的使用方法:

MySQL 语法

<?php $dbhost = ' localhost:3306 ' ; // mysql服务器主机地址 $dbuser = ' root ' ; // mysql用户名 $dbpass = ' 123456 ' ; // mysql用户名密码 $conn = mysqli_connect ( $dbhost , $dbuser , $dbpass ) ; if ( ! $conn ) { die ( ' 连接失败: ' . mysqli_error ( $conn ) ) ; } // 设置编码,防止中文乱码 mysqli_query ( $conn , " set names utf8 " ) ; $sql = ' SELECT id, title, author, submission_date FROM article ' ; mysqli_select_db ( $conn , ' CodeBaoku ' ) ; $retval = mysqli_query ( $conn , $sql ) ; if ( ! $retval ) { die ( ' 无法读取数据: ' . mysqli_error ( $conn ) ) ; } echo ' <h2>编程宝库 mysqli_fetch_array 测试</h2> ' ; echo ' <table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr> ' ; while ( $row = mysqli_fetch_array ( $retval , MYSQLI_NUM ) ) { echo " <tr><td> {$row[0]} </td> " . " <td> {$row[1]} </td> " . " <td> {$row[2]} </td> " . " <td> {$row[3]} </td> " . " </tr> " ; } echo ' </table> ' ; // 释放内存 mysqli_free_result ( $retval ) ; mysqli_close ( $conn ) ; ?>

我们使用 SELECT 语句从 MySQL 表中读取数据。如果需要选取符合一定条件的数据,就需要使用 WHERE 子句。WHERE 子句中可以包含各种条件的组合。MySQL WHERE 子句的语法:SELECT field1, field2,...