12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
ADADADADAD
mysql数据库 时间:2024-12-03 10:29:14
作者:文/会员上传
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
通过预处理语句进行增删改查为什么使用预处理语句关于预处理语句我们在上篇教程中已经简单介绍过,我们可以将其与视图模板类比,所谓预处理语句就是预定义的 SQL 语句模板,其中
以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。
关于预处理语句我们在上篇教程中已经简单介绍过,我们可以将其与视图模板类比,所谓预处理语句就是预定义的 SQL 语句模板,其中的具体参数值通过占位符替代:
INSERT INTO REGISTRY (name, value) VALUES (?, ?)INSERT INTO REGISTRY (name, value) VALUES (:name, :value)
然后在后续真正要执行 SQL 语句之前,再通过特定 API 方法将具体参数值与对应占位符进行绑定和映射。就好比定义的视图模板也是将变量通过特定占位符替代,然后真正渲染时将变量值传递进来填充和渲染一样。
为什么要费这番周折呢?直接用前面演示的 query
方法进行增删改查操作它不香吗?呃,那我们接下来来说说预处理语句的好处,或者说为什么要使用预处理语句进行数据库交互,好处有二:
综上,从性能和安全角度考虑,推荐使用预处理语句处理数据库的增删改查操作。
增删改查示例代码接下来,我们基于 PDO 提供的预处理语句 API 实现 MySQL 数据库的增删改查操作,我们将通过面向对象的方式来实现:
<?phpclass Post{public $id;public $title;public $content;public $created_at;/** * @var PDO */protected $pdo;public function __construct(PDO $pdo = null){if ($pdo != null) {$this->pdo = $pdo;}}public function insert($title, $content){$sql = 'INSERT INTO `post` (title, content, created_at) VALUES (:title, :content, :created_at)';try {// 准备预处理语句$stmt = $this->pdo->prepare($sql);// 获取当前时间对应的格式化字符串:2020-05-28 13:00:00$datetime = date('Y-m-d H:i:s', time());// 绑定参数值$stmt->bindParam(':title', $title, PDO::PARAM_STR);$stmt->bindParam(':content', $content, PDO::PARAM_STR);$stmt->bindParam(':created_at', $datetime, PDO::PARAM_STR);// 执行语句$stmt->execute();return $this->pdo->lastInsertId();// 返回插入记录对应ID} catch (PDOException $e) {printf("数据库插入失败: %s\n", $e->getMessage());}}public function select($id){$sql = 'SELECT * FROM `post` WHERE id = ?';try {// 准备预处理语句$stmt = $this->pdo->prepare($sql);// 绑定参数值$stmt->bindValue(1, $id, PDO::PARAM_INT);// 执行语句$stmt->execute();return $stmt->fetchObject(self::class);// 以对象方式返回结果集} catch (PDOException $e) {printf("数据库查询失败: %s\n", $e->getMessage());}}public function selectAll(){$sql = 'SELECT * FROM `post` ORDER BY id DESC';try {// 准备预处理语句$stmt = $this->pdo->prepare($sql);// 执行语句$stmt->execute();return $stmt->fetchAll();// 返回所有结果集} catch (PDOException $e) {printf("数据库查询失败: %s\n", $e->getMessage());}}public function update($id){$sql = 'UPDATE `post` SET created_at = :created_at WHERE id = :id';try {// 准备预处理语句$stmt = $this->pdo->prepare($sql);$datetime = date('Y-m-d H:i:s', time());// 绑定参数值$stmt->bindParam(':created_at', $datetime, PDO::PARAM_STR);$stmt->bindValue(':id', $id, PDO::PARAM_INT);// 执行语句$stmt->execute();return $stmt->rowCount();} catch (PDOException $e) {printf("数据库更新失败: %s\n", $e->getMessage());}}public function delete($id){$sql = 'DELETE FROM `post` WHERE id = ?';try {// 准备预处理语句$stmt = $this->pdo->prepare($sql);// 绑定参数值$stmt->bindValue(1, $id, PDO::PARAM_INT);// 执行语句$stmt->execute();return $stmt->rowCount();} catch (PDOException $e) {printf("数据库删除失败: %s\n", $e->getMessage());}}}
我们构建了一个 Post
类,然后在构造函数中初始化 $pdo
实例(从外部传入),然后将基于预处理语句实现的增删改查操作分解到对应的类方法中。整体逻辑非常简单,以 insert
为例,首先通过 PDO 对象的 prepare 方法传入 SQL 模板构建预处理语句,该方法返回 PDOStatement 对象,接下来,就是调用该对像的 bindParam 方法绑定具体参数值,该方法的第一个参数是占位符,第二个参数是参数值,第三个参数是值类型(对应的常量可以在 PDO 预定义常量中查询),绑定好参数后,就可以调用 PDOStatement 对象的 execute 方法执行预处理语句了。
对于插入操作,可以通过 PDO 对象上的 lastInsertId 方法返回插入记录的主键 ID,对于更新和删除方法,可以通过 PDOStatement 对象上的 rowCount 方法返回受影响行数表示是否操作成功。对于查询操作,可以通过 PDOStatement 对象的 fetch 方法返回单条记录,也可以通过 fetchObject 方法返回映射到指定类后的对象实例(也是单条记录),对于多个结果,可以通过 fetchAll 方法返回。
需要注意的是,在声明预处理语句的时候,可以通过 ?
占位符,也可以通过 :name
这种可读性更好的占位符,然后在绑定参数时,既可以通过 bindValue 也可以通过 bindParam 方法,两者传递参数一样,只是对于 ?
占位符,需要通过数值序号建立与 SQL 模板的映射(从 1 开始)。
结合代码和 PHP 官方文档理解上面的代码并不困难,接下来,我们来编写测试代码:
// 初始化 PDO 连接实例$dsn = 'mysql:host=127.0.0.1;port=3306;dbname=test;charset=utf8mb4';$user = 'root';$pass = 'root';try {$pdo = new PDO($dsn, $user, $pass);} catch (PDOException $e) {printf("数据库连接失败: %s\n", $e->getMessage());}// 测试代码$post = new Post($pdo);// insert$title = '这是一篇测试文章以上就是通过PDO扩展与MySQL数据库交互 实现增删改查实现和数据库事务的详细内容,更多请关注其它相关文章!
11-20
11-19
11-20
11-20
11-20
11-19
11-20
11-20
11-19
11-20
11-19
11-19
11-19
11-19
11-19
11-19