博客列表 >PDO操作数据库

PDO操作数据库

昔年
昔年原创
2020年05月08日 14:41:31692浏览

PDO 操作数据库

1.创建数据表

  1. drop table if exists 'category';
  2. create table 'category' (
  3. 'id' int(10) unsigned not null AUTO_INCREMENT,
  4. 'name' varchar(16) COLLATE utf8mb4_unicode_ci not null,
  5. 'cate_order' int(10) not null,
  6. 'description' varchar(100) COLLATE utf8mb4_unicode_ci not null,
  7. 'parent_id' int(10) not null,
  8. 'created_at' timestamp null DEFAULT null,
  9. 'updated_at' timestamp null DEFAULT null,
  10. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

2.连接数据库

2.1数据库配置文件

  1. <?php
  2. namespace pdo_edu;
  3. return [
  4. 'type' => $type ?? 'mysql',
  5. 'host' => $host ?? 'localhost',
  6. 'chartset' => $charset ?? 'utf8',
  7. 'dbname' => $dbname ?? 'phpedu',
  8. 'username' => $username ?? 'root',
  9. 'password' => $pasword ?? 'root',
  10. 'port' => $port ?? '3306'
  11. ];

2.1使用pdo链接数据

  1. <?php
  2. namespace pdo_edu;
  3. use Exception;
  4. use PDO;
  5. $config = require 'config/database.php';
  6. extract($config);
  7. //创建DSN
  8. $dsn = sprintf("%s:host=%s;dbname=%s", $type, $host, $dbname);
  9. // var_dump($dsn);
  10. try {
  11. //链接数据库
  12. $pdo = new PDO($dsn, $username, $password);
  13. $pdo->query("set names utf8");
  14. } catch (Exception $e) {
  15. die($e->getMessage());
  16. }

3.使用PDO实现对数据库的读操作

  1. <?php
  2. namespace select;
  3. use PDO;
  4. header("Content-Type: text/html; charset=UTF-8");
  5. //1.链接数据库
  6. require 'connect.php';
  7. //2.操作数据表
  8. $sql = "select * from `category` where `parent_id` = ?";
  9. // 预处理对象$stmt:为了防止 SQL注入
  10. $stmt = $pdo->prepare($sql);
  11. $stmt->execute([1]);
  12. // $categories = $stmt->fetchAll(PDO::FETCH_ASSOC);
  13. // var_dump($categories);
  14. while ($category = $stmt->fetch(PDO::FETCH_ASSOC)) {
  15. printf("<pre>%s</pre>", print_r($category, true));
  16. }
  17. //3.关闭链接
  18. unset($pdo);

4.使用PDO实现对数据的增操作

  1. <?php
  2. namespace insert;
  3. use PDO;
  4. //1.链接数据库
  5. require 'connect.php';
  6. //2.操作数据表
  7. $sql = "insert `category` set `name`=?, `cate_order`=?, `description`=?, `parent_id`=?, `created_at`=?, `updated_at`=? ";
  8. // echo $sql;
  9. // exit;
  10. $stmt = $pdo->prepare($sql);
  11. $data = [
  12. '网易新闻', '6', '网易新闻是网易倾力打造的精品应用,已然成为国内第一新闻客户端,因体验最流畅、新闻最快速、评论最犀利而备受推崇',
  13. '1', '2020-05-08 12:00:00', '2020-05-08 12:18:12'
  14. ];
  15. $stmt->execute($data);
  16. //判断是否执行成功
  17. if ($stmt->rowCount() === 1) {
  18. echo '新增成功,新增的主键是' . $pdo->lastInsertId();
  19. } else {
  20. echo '新增失败';
  21. print_r($stmt->errorInfo());
  22. }
  23. //3.关闭链接
  24. unset($pdo);

5.使用PDO实现对数据的改操作

  1. <?php
  2. namespace update;
  3. use PDO;
  4. //1.链接数据库
  5. require 'connect.php';
  6. //2.数据库操作
  7. $sql = "update `category` set `description`=? where `id` =? ";
  8. $stmt = $pdo->prepare($sql);
  9. $data = ['网易新闻融合资讯平台及原创策划为一体,自1998年成立起始终保持市场领先地位。', 12];
  10. $stmt->execute($data);
  11. //判断是否执行成功
  12. if ($stmt->rowCount() === 1) {
  13. echo '更新成功';
  14. } else {
  15. echo '更新失败';
  16. print_r($pdo->errorInfo());
  17. }
  18. //3.关闭链接
  19. unset($pdo);

6.使用PDO实现对数据库的删操作

  1. <?php
  2. namespace delete;
  3. use PDO;
  4. //1.建立链接
  5. require "connect.php";
  6. //2.数据库操作
  7. $sql = "delete from `category` where `id`=?";
  8. // $sql = "DELETE FROM `staffs` WHERE `id`=:id";
  9. // echo $sql;
  10. $stmt = $pdo->prepare($sql);
  11. $stmt->execute(['13']);
  12. if ($stmt->rowCount() === 1) {
  13. echo '删除成功';
  14. } else {
  15. echo '删除失败';
  16. print_r($pdo->errorInfo());
  17. }
  18. //3.关闭链接
  19. unset($pdo);

总结:使用PDO操作数据库主要有3个步骤,第一步是链接数据库,由于可能经常需要使用到这个操作,可以把它单独拿出来写在一个文件中,后面需要连接数据库时引入这个文件就行;第二歩对数据库进行操作,主要先写SQL语句然后使用prepare方法对SQL语句进行预处理最后执行execute方法传入相应的参数;第三歩是可选的,关闭连接,直接用unset方法把pdo对象置空就行。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议