当前位置: 代码网 > it编程>编程语言>Php > 【WEB安全】 PHP基础与数据库教学下(超详细)

【WEB安全】 PHP基础与数据库教学下(超详细)

2024年08月02日 Php 我要评论
PHP 连接 MySQL在 PHP 使用 MySQL 数据库前,你需要先将它们连接。PHP 5 及以上版本建议使用以下方式连接 MySQL :MySQLi extension ("i" 意为 improved)在 PHP 早起版本中我们使用 MySQL 扩展。但该扩展在 2012 年开始不建议使用。我是该用 MySQLi ,还是 PDO?如果你需要一个简短的回答,即 "你习惯哪个就用哪个"。

文章目录

php与mysql

简述

mysqli 和 pdo 连接 mysql 实例

linux 和 windows: 在 php5 mysql 包安装时 mysqli 扩展多事情况下是自动安装的。

pdo 安装

实例 (mysqli - 面向对象)

实例 (mysqli - 面向过程)

实例 (pdo)

使用 mysqli 和 pdo 向 mysql 插入数据

实例 (mysqli - 面向对象)

实例 (mysqli - 面向过程)

实例 (pdo)

php mysql 插入多条数据

实例 (mysqli - 面向对象)

实例 (mysqli - 面向过程)

实例 (pdo)

使用预处理语句

php mysql 预处理语句

预处理语句的工作原理如下:

mysqli 预处理语句

实例 (mysqli 使用预处理语句)

pdo 中的预处理语句

实例 (pdo 使用预处理语句)

php mysql 读取数据

实例 (mysqli - 面向对象)

实例 (pdo)


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

在下一节内容中,你将学习到如何连接到数据源!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com