MySQL SELECT语句用于从数据库表中选择数据,并将选择的数据以表的形式返回。
不同场景下使用 SELECT 语句的语法如下:
/*select one column*/
SELECT column1 FROM table_name;
/*select multiple columns*/
SELECT column1, column2, ...
FROM table_name;
/*select all columns of a table*/
SELECT * FROM table_name;
除此之外,要连接到 MySQL 服务器,还可以使用 mysqli_connect() 函数。建立连接后,可以使用 mysqli_query() 函数对数据库执行查询。
num_rows() 函数可用于检查返回的行数是否超过零。然后,可以使用 fetch_assoc() 函数以关联数组的形式获取结果集。稍后可以使用 free_result() 函数释放与结果关联的内存。
选择数据 - 面向对象风格
考虑一个包含名为 employee的表数据库具有以下记录的员工:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
1 | John | London | 25 | 3000 |
2 | Marry | New York | 24 | 2750 |
3 | Jo | Paris | 27 | 2800 |
4 | Kim | Amsterdam | 30 | 3100 |
5 | Ramesh | New Delhi | 28 | 3000 |
6 | Huang | Beijing | 28 | 2800 |
以下示例演示如何选择姓名、年龄和城市记录使用面向对象的样式出现在 Employee 表中。
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDatabase";
//建立连接
$mysqli = new mysqli($servername, $username, $password, $dbname);
//检查连接
if ($mysqli->connect_errno) {
echo "Failed to connect to MySQL: ". $mysqli->connect_error;
exit();
}
//从数据库获取查询结果
$sql = "SELECT Name, Age, Salary FROM Employee";
$result = $mysqli->query($sql);
//获取关联数组
while ($row = $result->fetch_assoc()) {
printf("%s, %d, %s\n", $row["Name"], $row["Age"], $row["City"]);
}
//释放结果集
$result->free_result();
//关闭连接
$mysqli->close();
?>
上述代码的输出将是:
John, 25, London
Marry, 24, New York
Jo, 27, Paris
Kim, 30, Amsterdam
Ramesh, 28, New Delhi
Huang, 28, Beijing
选择数据 - 过程样式
要使用面向过程风格获得相同的结果,可以使用以下脚本。
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDatabase";
//建立连接
$mysqli = mysqli_connect($servername, $username, $password, $dbname);
//检查连接
if (mysqli_connect_errno()) {
echo "Failed to connect to MySQL: ". mysqli_connect_error();
exit();
}
//从数据库获取查询结果
$sql = "SELECT Name, Age, Salary FROM Employee";
$result = mysqli_query($mysqli, $sql);
//获取关联数组
while ($row = mysqli_fetch_assoc($result)) {
printf("%s, %d, %s\n", $row["Name"], $row["Age"], $row["City"]);
}
//释放结果集
mysqli_free_result($result);
//关闭连接
mysqli_close($mysqli);
?>
上述代码的输出将是:
John, 25, London
Marry, 24, New York
Jo, 27, Paris
Kim, 30, Amsterdam
Ramesh, 28, New Delhi
Huang, 28, Beijing
完整 PHP MySQLi 参考
有关 PHP MySQLi 扩展的所有属性、方法和功能的完整参考,请参阅 PHP MySQLi 参考。