文章目录
linux 和 windows: 在 php5 mysql 包安装时 mysqli 扩展多事情况下是自动安装的。
php与mysql
简述
php 连接 mysql
在 php 使用 mysql 数据库前,你需要先将它们连接。
php 5 及以上版本建议使用以下方式连接 mysql :
mysqli extension ("i" 意为 improved)
pdo (php data objects)
在 php 早起版本中我们使用 mysql 扩展。但该扩展在 2012 年开始不建议使用。
我是该用 mysqli ,还是 pdo?
如果你需要一个简短的回答,即 "你习惯哪个就用哪个"。
mysqli 和 pdo 有它们自己的优势:
pdo 应用在 12 种不同数据库中, mysqli 只针对 mysql 数据库。
所以,如果你的项目需要在多种数据库中切换,建议使用 pdo ,这样你只需要修改连接字符串和部分查询语句即可。使用 mysqli, 如果不同数据库,你需要重新所有代码,包括查询。
两者都是面向对象, 但 mysqli 还提供了 api 接口。
两者都支持预处理语句。 预处理语句可以防止 sql 注入,对于 web 项目的安全性是非常重要的。
mysqli 和 pdo 连接 mysql 实例
在本章节及接下来的章节中,我们会使用以下三种方式来演示 php 操作 mysql:
mysqli (面向对象)
mysqli (面向过程)
pdo
mysqli installation
linux 和 windows: 在 php5 mysql 包安装时 mysqli 扩展多事情况下是自动安装的。
安装详细信息,请查看: http://php.net/manual/en/mysqli.installation.php
pdo 安装
for 安装详细信息,请查看: http://php.net/manual/en/pdo.installation.php
连接 mysql
在我们访问 mysql 数据库前,我们需要先连接到数据库服务器:
<?php
$servername = "localhost";
$username = "username";
$password = "password";
// 创建连接
$conn = new mysqli($servername, $username, $password);
// 检测连接
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
}
echo "connected successfully";
?>
面向过程
<?php
$servername = "localhost";
$username = "username";
$password = "password";
// 创建连接
$conn = mysqli_connect($servername, $username, $password);
// 检测连接
if (!$conn) {
die("connection failed: " . mysqli_connect_error());
}
echo "connected successfully";
?>
pdo
<?php
$servername = "localhost";
$username = "username";
$password = "password";
try {
$conn = new pdo("mysql:host=$servername;dbname=mydb", $username, $password);
echo "connected successfully";
}
catch(pdoexception $e)
{
echo $e->getmessage();
}
?>
关闭连接
连接在脚本执行完后会自动关闭。你也可以使用以下代码来关闭连接:
实例 (mysqli - 面向对象)
$conn->close();
实例 (mysqli - 面向过程)
mysqli_close($conn);
实例 (pdo)
$conn = null;
现在,你已经知道如何将 mysql 数据库连接到 php 了,接下来,你应该了解 php 是如何创建数据库的!
php 创建 mysql 表
在 php 中创建完数据库之后,我们需要在数据库中创建一个或者多个的数据表。
一个数据表有一个唯一名称,并有行和列组成。
使用 mysqli 和 pdo 创建 mysql 表
create table 语句用于创建 mysql 表。
创建表前,我们需要使用 use mydb 来选择要操作的数据库:
use mydb;
我们将创建一个名为 "myguests" 的表,有 5 个列: "id", "firstname", "lastname", "email" 和 "reg_date":
create table myguests (
id int(6) unsigned auto_increment primary key,
firstname varchar(30) not null,
lastname varchar(30) not null,
email varchar(50),
reg_date timestamp
)
上表中的注意事项:
数据类型指定列可以存储什么类型的数据。完整的数据类型请参考我们的 数据类型参考手册。
在设置了数据类型后,你可以为每个列指定其他选项的属性:
not null - 每一行都必须含有值(不能为空),null 值是不允许的。
default value - 设置默认值
unsigned - 使用无符号数值类型,0 及正数
auto increment - 设置 mysql 字段的值在新增记录时每次自动增长 1
primary key - 设置数据表中每条记录的唯一标识。 通常列的 primary key 设置为 id 数值,与auto_increment 一起使用。
每个表都应该有一个主键(本列为 "id" 列),主键必须包含唯一的值。
以下实例展示了如何在 php 中创建表:
实例 (mysqli - 面向对象)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydb";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检测连接
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
}
// sql to create table
$sql = "create table myguests (
id int(6) unsigned auto_increment primary key,
firstname varchar(30) not null,
lastname varchar(30) not null,
email varchar(50),
reg_date timestamp
)";
if ($conn->query($sql) === true) {
echo "table myguests created successfully";
} else {
echo "error creating table: " . $conn->error;
}
$conn->close();
?>
实例 (mysqli - 面向过程)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydb";
// 创建连接
$conn = mysqli_connect($servername, $username, $password, $dbname);
// 检测连接
if (!$conn) {
die("connection failed: " . mysqli_connect_error());
}
// sql to create table
$sql = "create table myguests (
id int(6) unsigned auto_increment primary key,
firstname varchar(30) not null,
lastname varchar(30) not null,
email varchar(50),
reg_date timestamp
)";
if (mysqli_query($conn, $sql)) {
echo "table myguests created successfully";
} else {
echo "error creating table: " . mysqli_error($conn);
}
mysqli_close($conn);
?>
实例 (pdo)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydbpdo";
try {
$conn = new pdo("mysql:host=$servername;dbname=$dbname", $username, $password);
// set the pdo error mode to exception
$conn->setattribute(pdo::attr_errmode, pdo::errmode_exception);
// sql to create table
$sql = "create table myguests (
id int(6) unsigned auto_increment primary key,
firstname varchar(30) not null,
lastname varchar(30) not null,
email varchar(50),
reg_date timestamp
)";
// use exec() because no results are returned
$conn->exec($sql);
echo "table myguests created successfully";
}
catch(pdoexception $e)
{
echo $sql . "<br>" . $e->getmessage();
}
$conn = null;
?>
现在,你的 mysql 数据库已经创建好,并且有了需要的表格,但是这还不够,因为数据表中还没有数据,此时表还只是个架子,所以,我们需要继续完善数据表,为它插入一些数据!
使用 mysqli 和 pdo 向 mysql 插入数据
在创建完数据库和表后,我们可以向表中添加数据。
以下为一些语法规则:
php 中 sql 查询语句必须使用引号
在 sql 查询语句中的字符串值必须加引号
数值的值不需要引号
null 值不需要引号
insert into 语句通常用于向 mysql 表添加新的记录:
insert into table_name (column1, column2, column3,...)
values (value1, value2, value3,...)
学习更多关于 sql 知识,请查看我们的 sql 教程。
在前面的几个章节中我们已经创建了表 "myguests",表字段有: "id", "firstname", "lastname", "email" 和 "reg_date"。 现在,让我们开始向表填充数据。
note 注意: 如果列设置 auto_increment (如 "id" 列) 或 timestamp (如 "reg_date" 列),,我们就不需要在 sql 查询语句中指定值; mysql 会自动为该列添加值。
以下实例向 "myguests" 表添加了新的记录:
实例 (mysqli - 面向对象)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydb";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检测连接
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
}
$sql = "insert into myguests (firstname, lastname, email)
values ('john', 'doe', 'john@example.com')";
if ($conn->query($sql) === true) {
echo "new record created successfully";
} else {
echo "error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
?>
实例 (mysqli - 面向过程)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydb";
// 创建连接
$conn = mysqli_connect($servername, $username, $password, $dbname);
// 检测连接
if (!$conn) {
die("connection failed: " . mysqli_connect_error());
}
$sql = "insert into myguests (firstname, lastname, email)
values ('john', 'doe', 'john@example.com')";
if (mysqli_query($conn, $sql)) {
echo "new record created successfully";
} else {
echo "error: " . $sql . "<br>" . mysqli_error($conn);
}
mysqli_close($conn);
?>
实例 (pdo)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydbpdo";
try {
$conn = new pdo("mysql:host=$servername;dbname=$dbname", $username, $password);
// set the pdo error mode to exception
$conn->setattribute(pdo::attr_errmode, pdo::errmode_exception);
$sql = "insert into myguests (firstname, lastname, email)
values ('john', 'doe', 'john@example.com')";
// use exec() because no results are returned
$conn->exec($sql);
echo "new record created successfully";
}
catch(pdoexception $e)
{
echo $sql . "<br>" . $e->getmessage();
}
$conn = null;
?>
其实,你还可以在 php 的 mysql 数据库中插入多条数据,这将在下面的一节内容中提及。
php mysql 插入多条数据
一般情况下,insert 语句只能向 mysql 数据库添加一条语句,而本文将介绍如何使用函数批量的向数据表插入多条数据。
使用 mysqli 和 pdo 向 mysql 插入多条数据
mysqli_multi_query() 函数可用来执行多条sql语句。
以下实例向 "myguests" 表添加了三条新的记录:
实例 (mysqli - 面向对象)
<?php
$servername = "localhost";
$username = "username";
$password =
"password";
$dbname =
"mydb";
// 创建链接
$conn =
new mysqli($servername, $username, $password, $dbname);
// 检查链接
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
}
$sql = "insert into
myguests (firstname, lastname, email)
values ('john', 'doe', 'john@example.com');";
$sql .= "insert into
myguests (firstname, lastname, email)
values ('mary', 'moe', 'mary@example.com');";
$sql .= "insert into
myguests (firstname, lastname, email)
values ('julie', 'dooley', 'julie@example.com')";
if ($conn->multi_query($sql) === true) {
echo "new
records created successfully";
} else {
echo
"error: " . $sql . "
" . $conn->error;
}
$conn->close();
?>
note 请注意,每个sql语句必须用分号隔开。
实例 (mysqli - 面向过程)
<?php
$servername = "localhost";
$username = "username";
$password =
"password";
$dbname =
"mydb";
// 创建链接
$conn = mysqli_connect($servername, $username, $password,
$dbname);
// 检查链接
if (!$conn) {
die("connection
failed: " . mysqli_connect_error());
}
$sql = "insert into
myguests (firstname, lastname, email)
values ('john', 'doe', 'john@example.com');";
$sql .= "insert into
myguests (firstname, lastname, email)
values ('mary', 'moe', 'mary@example.com');";
$sql .= "insert into
myguests (firstname, lastname, email)
values ('julie', 'dooley', 'julie@example.com')";
if (mysqli_multi_query($conn, $sql)) {
echo "new
records
created successfully";
} else {
echo "error: "
. $sql . "
" . mysqli_error($conn);
}
mysqli_close($conn);
?>
实例 (pdo)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname =
"mydbpdo";
try {
$conn = new pdo("mysql:host=$servername;dbname=$dbname",
$username, $password);
// set the pdo error mode to exception
$conn->setattribute(pdo::attr_errmode,
pdo::errmode_exception);
// 开始事务
$conn->begintransaction();
// sql 语句
$conn->exec("insert into myguests (firstname, lastname, email)
values ('john', 'doe', 'john@example.com')");
$conn->exec("insert into myguests (firstname, lastname, email)
values ('mary', 'moe', 'mary@example.com')");
$conn->exec("insert into myguests (firstname, lastname, email)
values ('julie', 'dooley', 'julie@example.com')");
// commit the transaction
$conn->commit();
echo "new records created successfully";
}
catch(pdoexception $e)
{
// roll back the transaction if something failed
$conn->rollback();
echo $sql . "
" . $e->getmessage();
}
$conn = null;
?>
使用预处理语句
mysqli 扩展提供了第二种方式用于插入语句。
我们可以预处理语句及绑定参数。
mysql 扩展可以不带数据发送语句或查询到mysql数据库。 你可以向列关联或 "绑定" 变量。
example (mysqli 使用预处理语句)
<?php
$servername = "localhost";
$username = "username";
$password =
"password";
$dbname =
"mydb";
// create connection
$conn =
new mysqli($servername, $username, $password, $dbname);
// check connection
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
} else {
$sql = "insert into
myguests (firstname, lastname, email) values(?, ?, ?)";
// 为 mysqli_stmt_prepare() 初始化
statement 对象
$stmt =
mysqli_stmt_init($conn);
//预处理语句
if (mysqli_stmt_prepare($stmt, $sql)) {
// 绑定参数
mysqli_stmt_bind_param($stmt, 'sss', $firstname, $lastname, $email);
// 设置参数并执行
$firstname = 'john';
$lastname
= 'doe';
$email =
'john@example.com';
mysqli_stmt_execute($stmt);
$firstname = 'mary';
$lastname
= 'moe';
$email =
'mary@example.com';
mysqli_stmt_execute($stmt);
$firstname = 'julie';
$lastname = 'dooley';
$email =
'julie@example.com';
mysqli_stmt_execute($stmt);
}
}
?>
我们可以看到以上实例中使用模块化来处理问题。我们可以通过创建代码块实现更简单的读取和管理。
注意参数的绑定。让我们看下 mysqli_stmt_bind_param() 中的代码:
mysqli_stmt_bind_param($stmt, 'sss', $firstname, $lastname, $email);
该函数绑定参数查询并将参数传递给数据库。第二个参数是 "sss" 。以下列表展示了参数的类型。 s 字符告诉 mysql 参数是字符串。
可以是以下四种参数:
i - integer
d - double
s - string
b - blob
每个参数必须指定类型,来保证数据的安全性。通过类型的判断可以减少sql注入漏洞带来的风险。
php mysql 预处理语句
mysql 从4.1版本开始提供了一种名为预处理语句(prepared statement)的机制。
mysql 预处理语句不仅大大减少了需要传输的数据量,还提高了命令的处理效率。
预处理语句对于防止 mysql 注入是非常有用的。
预处理语句及绑定参数
预处理语句用于执行多个相同的 sql 语句,并且执行效率更高。
预处理语句的工作原理如下:
预处理:创建 sql 语句模板并发送到数据库。预留的值使用参数 "?" 标记 。例如:insert into myguests (firstname, lastname, email) values(?, ?, ?)
数据库解析,编译,对sql语句模板执行查询优化,并存储结果不输出
执行:最后,将应用绑定的值传递给参数("?" 标记),数据库执行语句。应用可以多次执行语句,如果参数的值不一样。
相比于直接执行sql语句,预处理语句有两个主要优点:
预处理语句大大减少了分析时间,只做了一次查询(虽然语句多次执行)
绑定参数减少了服务器带宽,你只需要发送查询的参数,而不是整个语句
预处理语句针对sql注入是非常有用的,因为 参数值发送后使用不同的协议,保证了数据的合法性。
mysqli 预处理语句
以下实例在 mysqli 中使用了预处理语句,并绑定了相应的参数:
实例 (mysqli 使用预处理语句)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydb";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检测连接
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
}
// prepare and bind
$stmt = $conn->prepare("insert into myguests (firstname, lastname, email) values(?, ?, ?)");
$stmt->bind_param("sss", $firstname, $lastname, $email);
// 设置参数并执行
$firstname = "john";
$lastname = "doe";
$email = "john@example.com";
$stmt->execute();
$firstname = "mary";
$lastname = "moe";
$email = "mary@example.com";
$stmt->execute();
$firstname = "julie";
$lastname = "dooley";
$email = "julie@example.com";
$stmt->execute();
echo "new records created successfully";
$stmt->close();
$conn->close();
?>
解析以下实例的每行代码:
"insert into myguests (firstname, lastname, email) values(?, ?, ?)"
在 sql 语句中,我们使用了问号 (?),在此我们可以将问号替换为整型,字符串,双精度浮点型和布尔值。
接下来,让我们来看下 bind_param() 函数:
$stmt->bind_param("sss", $firstname, $lastname, $email);
该函数绑定了 sql 的参数,且告诉数据库参数的值。 "sss" 参数列处理其余参数的数据类型。s 字符告诉数据库该参数为字符串。
参数有以下四种类型:
i - integer(整型)
d - double(双精度浮点型)
s - string(字符串)
b - blob(布尔值)
每个参数都需要指定类型。
通过告诉数据库参数的数据类型,可以降低 sql 注入的风险。
note 注意: 如果你想插入其他数据(用户输入),对数据的验证是非常重要的。
pdo 中的预处理语句
以下实例我们在 pdo 中使用了预处理语句并绑定参数:
实例 (pdo 使用预处理语句)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydbpdo";
try {
$conn = new pdo("mysql:host=$servername;dbname=$dbname", $username, $password);
// 设置 pdo 错误模式为异常
$conn->setattribute(pdo::attr_errmode, pdo::errmode_exception);
// 预处理 sql 并绑定参数
$stmt = $conn->prepare("insert into myguests (firstname, lastname, email)
values (:firstname, :lastname, :email)");
$stmt->bindparam(':firstname', $firstname);
$stmt->bindparam(':lastname', $lastname);
$stmt->bindparam(':email', $email);
// 插入行
$firstname = "john";
$lastname = "doe";
$email = "john@example.com";
$stmt->execute();
// 插入其他行
$firstname = "mary";
$lastname = "moe";
$email = "mary@example.com";
$stmt->execute();
// 插入其他行
$firstname = "julie";
$lastname = "dooley";
$email = "julie@example.com";
$stmt->execute();
echo "new records created successfully";
}
catch(pdoexception $e)
{
echo $sql . "<br>" . $e->getmessage();
}
$conn = null;
?>
php mysql 读取数据
当 php 连接到 mysql 数据库后,需要向数据库读取数据?那么怎么读取呢?一起来看看。
从 mysql 数据库读取数据
select 语句用于从数据表中读取数据:
select column_name(s) from table_name
我们可以使用 * 号来读取所有数据表中的字段:
select * from table_name
如需学习更多关于 sql 的知识,请访问我们的 sql 教程。
以下实例中我们从表 myguests 读取了 id, firstname 和 lastname 列的数据并显示在页面上:
实例 (mysqli - 面向对象)
<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydb";
// 创建连接
$conn = mysqli_connect($servername, $username, $password, $dbname);
// 检测连接
if ($conn->connect_error) {
die("connection failed: " . $conn->connect_error);
}
$sql = "select id, firstname, lastname from myguests";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
// 输出每行数据
while($row = $result->fetch_assoc()) {
echo "id: ". $row["id"]. " - name: ". $row["firstname"]. " " . $row["lastname"]. "<br>";
}
} else {
echo "0 results";
}
mysqli_close($conn);
?>
以下实例读取了 myguests 表的所有记录并显示在 html 表格中:
实例 (pdo)
<?php
echo "<table style='border: solid 1px black;'>";
echo "<tr><th>id</th><th>firstname</th><th>lastname</th><th>email</th><th>reg date</th></tr>";
class tablerows extends recursiveiteratoriterator {
function __construct($it) {
parent::__construct($it, self::leaves_only);
}
function current() {
return "<td style='width: 150px; border: 1px solid black;'>" . parent::current(). "</td>";
}
function beginchildren() {
echo "<tr>";
}
function endchildren() {
echo "</tr>" . "\n";
}
}
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "mydbpdo";
try {
$conn = new pdo("mysql:host=$servername;dbname=$dbname", $username, $password);
$conn->setattribute(pdo::attr_errmode, pdo::errmode_exception);
$stmt = $conn->prepare("select * from myguests");
$stmt->execute();
// 设置结果集为关联数组
$result = $stmt->setfetchmode(pdo::fetch_assoc);
foreach(new tablerows(new recursivearrayiterator($stmt->fetchall())) as $k=>$v) {
echo $v;
}
$dsn = null;
}
catch(pdoexception $e)
{
echo "error: " . $e->getmessage();
}
$conn = null;
echo "</table>";
?>
php mysql where 子句
通过上一节的内容,你已经可以使用 mysql 的 select 命令从数据表中获取数据,本节我们可以用 where 命令来筛选出满足条件的结果。
where 子句用于过滤记录。
where 子句
where 子句用于提取满足指定标准的的记录。
语法
select column_name(s)
from table_name
where column_name operator value
如需学习更多关于 sql 的知识,请访问我们的 sql 教程。
为了让 php 执行上面的语句,我们必须使用 mysqli_query() 函数。该函数用于向 mysql 连接发送查询或命令。
实例
下面的实例将从 "persons" 表中选取所有 firstname='peter' 的行:
<?php
$con=mysqli_connect("example.com","peter","abc123","my_db");
// check connection
if (mysqli_connect_errno())
{
echo "failed to connect to mysql: " . mysqli_connect_error();
}
$result = mysqli_query($con,"select * from persons
where firstname='peter'");
while($row = mysqli_fetch_array($result))
{
echo $row['firstname'] . " " . $row['lastname'];
echo "<br>";
}
?>
以上代码将输出:
peter griffin
在下一节内容中,我们会讲解如何对筛选出来的记录进行排序。
php mysql order by 关键词
你可以对 mysql 数据库中的记录集进行排序,具体请阅读本节内容。
order by 关键词用于对记录集中的数据进行排序。
order by 关键词
order by 关键词用于对记录集中的数据进行排序。
order by 关键词默认对记录进行升序排序。
如果你想降序排序,请使用 desc 关键字。
语法
select column_name(s)
from table_name
order by column_name(s) asc|desc
如需学习更多关于 sql 的知识,请访问我们的 sql 教程。
实例
下面的实例选取 "persons" 表中存储的所有数据,并根据 "age" 列对结果进行排序:
<?php
$con=mysqli_connect("example.com","peter","abc123","my_db");
// check connection
if (mysqli_connect_errno())
{
echo "failed to connect to mysql: " . mysqli_connect_error();
}
$result = mysqli_query($con,"select * from persons order by age");
while($row = mysqli_fetch_array($result))
{
echo $row['firstname'];
echo " " . $row['lastname'];
echo " " . $row['age'];
echo "<br>";
}
mysqli_close($con);
?>
以上结果将输出:
glenn quagmire 33
peter griffin 35
根据两列进行排序
可以根据多个列进行排序。当按照多个列进行排序时,只有第一列的值相同时才使用第二列:
select column_name(s)
from table_name
order by column1, column2
php mysql update
对于 mysql 数据库中的数据你可以根据需要进行更新!
update 语句用于中修改数据库表中的数据。
更新数据库中的数据
update 语句用于更新数据库表中已存在的记录。
语法
update table_name
set column1=value, column2=value2,...
where some_column=some_value
注释:请注意 update 语法中的 where 子句。where 子句规定了哪些记录需要更新。如果您想省去 where 子句,所有的记录都会被更新!
如需学习更多关于 sql 的知识,请访问我们的 sql 教程。
为了让 php 执行上面的语句,我们必须使用 mysqli_query() 函数。该函数用于向 mysql 连接发送查询或命令。
实例
在本教程的前面章节中,我们创建了一个名为 "persons" 的表,如下所示:
firstname lastname age
peter griffin 35
glenn quagmire 33
下面的例子更新 "persons" 表的一些数据:
<?php
$con=mysqli_connect("example.com","peter","abc123","my_db");
// check connection
if (mysqli_connect_errno())
{
echo "failed to connect to mysql: " . mysqli_connect_error();
}
mysqli_query($con,"update persons set age=36
where firstname='peter' and lastname='griffin'");
mysqli_close($con);
?>
在这次更新后,"persons" 表如下所示:
firstname lastname age
peter griffin 36
glenn quagmire 33
php mysql delete
如果你不再需要 mysql 数据库中的某条记录了,那么你也可以根据需要将其删除!
delete 语句用于从数据库表中删除行。
删除数据库中的数据
delete from 语句用于从数据库表中删除记录。
语法
delete from table_name
where some_column = some_value
注释:请注意 delete 语法中的 where 子句。where 子句规定了哪些记录需要删除。如果您想省去 where 子句,所有的记录都会被删除!
如需学习更多关于 sql 的知识,请访问我们的 sql 教程。
为了让 php 执行上面的语句,我们必须使用 mysqli_query() 函数。该函数用于向 mysql 连接发送查询或命令。
实例
请看下面的 "persons" 表:
firstname lastname age
peter griffin 35
glenn quagmire 33
下面的实例删除 "persons" 表中所有 lastname='griffin' 的记录:
<?php
$con=mysqli_connect("example.com","peter","abc123","my_db");
// check connection
if (mysqli_connect_errno())
{
echo "failed to connect to mysql: " . mysqli_connect_error();
}
mysqli_query($con,"delete from persons where lastname='griffin'");
mysqli_close($con);
?>
在这次删除后,"persons" 表如下所示:
firstname lastname age
glenn quagmire 33
在下一节内容中,你将学习到如何连接到数据源!
发表评论