Blogger Information
Blog 26
fans 0
comment 0
visits 21880
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
PHP操作数据库(MySQLi版)
溪边小树
Original
638 people have browsed it

上次课程学习了PDO,可以操作所有数据库,今天学习Mysqli,只用于操作Mysql数据库,在很多场合中还是有用到。

示例演示

database.php

  1. <?php
  2. namespace mysqli_edu;
  3. // 数据库连接配置参数
  4. return [
  5. // 数据库的类型
  6. 'type' => $type ?? 'mysql',
  7. // 数据库默认主机
  8. 'host' => $host?? 'localhost',
  9. // 默认数据库
  10. 'dbname'=> $dbname ?? 'phpedu',
  11. // 默认字符编码集
  12. 'charset'=> $charset ?? 'utf8',
  13. // 默认端口号
  14. 'port'=> $port ?? '3306',
  15. // 默认的用户名
  16. 'username'=> $username ?? 'admin',
  17. // 默认的用户密码
  18. 'password'=> $password ?? 'admin123',
  19. ];

connect.php

  1. <?php
  2. namespace mysqli_edu;
  3. use mysqli;
  4. // 1. 加载外部的数据库连接参数
  5. $config = require __DIR__ . '/config/database.php';
  6. // 2. mysqli 连接四大参数
  7. // 2.1 数据库的主机名: host
  8. // 2.1 用户名: username
  9. // 2.3 用户密码: password
  10. // 2.4 默认的数据库 :dbname
  11. // $host = $config['host'];
  12. // $dbname = $config['dbname'];
  13. // $username = $config['username'];
  14. // $password = $config['password'];
  15. /**
  16. * @var string $host
  17. * @var string $username
  18. * @var string $password
  19. * @var string $dbanme
  20. * @var string $charset
  21. */
  22. extract($config);
  23. // 将关联数组中的键值对, 转为变量的名值对
  24. // 2. 连接数据库
  25. $mysqli = new mysqli($host, $username, $password, $dbname);
  26. // 3. 判断是否连接成功?
  27. if ($mysqli->connect_errno) echo $mysqli->connect_error;
  28. // 4. 设置客户端默认的字符编码集
  29. $mysqli->set_charset($charset);
  30. //var_dump($mysqli);

select1.php

select2.php

  1. <?php
  2. // 查询1: 单条记录
  3. // 1. 连接数据库
  4. require 'connect.php';
  5. // 2. 操作数据库
  6. $sql = "SELECT `id`, `name` FROM `goods` WHERE `price` >80";
  7. // 查询使用:$mysqli->query($sql),
  8. // 返回值
  9. // 1. 如果是查询: 返回一个:结果集对象
  10. // 2. 如果是写操作: 新增, 更新, 删除, 执行成功返回布尔值
  11. // true:成功, false : 失败, 然后通过 affected_rows属性返回受影响的记录数量
  12. $mysqli_result = $mysqli->query($sql);
  13. //var_dump($mysqli_result);
  14. // fetch_array():一次输出一条记录,并自动下移指针
  15. // $staff = $mysqli_result->fetch_array(MYSQLI_BOTH);
  16. // printf('<pre>%s</pre>', print_r($staff, true));
  17. // $staff = $mysqli_result->fetch_array(MYSQLI_ASSOC);
  18. // printf('<pre>%s</pre>', print_r($staff, true));
  19. // $staff = $mysqli_result->fetch_array(MYSQLI_NUM);
  20. // printf('<pre>%s</pre>', print_r($staff, true));
  21. // 只返回关联部分: $mysqli_result->fetch_array(MYSQLI_ASSOC);语法糖
  22. // $staff = $mysqli_result->fetch_assoc();
  23. // printf('<pre>%s</pre>', print_r($staff, true));
  24. // 只返回索引部分: $mysqli_result->fetch_array(MYSQLI_NUM);语法糖
  25. // $staff = $mysqli_result->fetch_row();
  26. // printf('<pre>%s</pre>', print_r($staff, true));
  27. // 指针复位
  28. //$mysqli_result->data_seek(0);
  29. if ($mysqli_result && $mysqli_result->num_rows > 0 ) {
  30. while ($staff = $mysqli_result->fetch_assoc()) {
  31. printf('<pre>%s</pre>', print_r($staff, true));
  32. }
  33. } else {
  34. echo '查询失败或没有查询到满足条件的商品';
  35. }
  36. // 3. 关闭连接
  37. // 释放结果集
  38. //$mysqli_result->free_result();
  39. $mysqli->close();
  40. ------------------------------------
  41. // 查询2: 多条记录
  42. // 1. 连接数据库
  43. require 'connect.php';
  44. // 2. 操作数据库
  45. $sql = "SELECT `id`, `name` ,`price` FROM `goods` WHERE `price` >50";
  46. $mysqli_result = $mysqli->query($sql);
  47. if ($mysqli_result && $mysqli_result->num_rows > 0 ) {
  48. $goods = $mysqli_result->fetch_all();
  49. foreach ($goods as $good) {
  50. // vprintf() 与 printf()功能一样, 区别 就是参数是数组
  51. vprintf('<li>编号: %s , 商品名称: %s , 价格: %s </li>', $good);
  52. //vprintf('<li>编号: %s , 商品名称: %s </li>', $good);
  53. // printf('<pre>%s</pre>', print_r($good, true));
  54. }
  55. } else {
  56. echo '查询失败或没有查询到满足条件的商品';
  57. }
  58. // 3. 关闭连接
  59. // 释放结果集
  60. //$mysqli_result->free_result();
  61. $mysqli->close();

insert.php

  1. <?php
  2. // 新增操作
  3. // 1. 连接数据库
  4. require 'connect.php';
  5. // 2. 操作数据库
  6. // 前端表单->json格式的字符串, php将这种json字符串转为数组/对象
  7. $arr = ['15', '帽子2', '30', '55'];
  8. array_walk($arr, function(&$item, $key, $length) {
  9. if ($key < $length-1 ) $item = "'$item'";
  10. }, count($arr));
  11. $data = implode(', ', $arr);
  12. $sql = "INSERT `goods` (`id`,`name`,`price`,`number`) VALUES ($data)";
  13. if ($mysqli->query($sql)) {
  14. if ($mysqli->affected_rows > 0) {
  15. echo '成功添加了 ' . $mysqli->affected_rows . ' 条记录, 新增记录主键ID: ' . $mysqli->insert_id;
  16. } else {
  17. echo '没有添加新记录';
  18. }
  19. } else {
  20. die('添加失败'. $mysqli->errno . ' : ' . $mysqli->error);
  21. }
  22. // 3. 关闭连接
  23. // 释放结果集
  24. $mysqli->close();

update.php

  1. <?php
  2. // 更新操作
  3. // 1. 连接数据库
  4. require 'connect.php';
  5. // 2. 操作数据库
  6. // 前端表单->json格式的字符串, php将这种json字符串转为数组/对象
  7. $arr = ['name'=>'裤子', 'price'=>'200'];
  8. array_walk($arr, function(&$item, $key) {
  9. $item = "`$key` = '$item'";
  10. });
  11. $data = implode(', ', $arr);
  12. $sql = "UPDATE `goods` SET " . $data . " WHERE `id` = 2";
  13. if ($mysqli->query($sql)) {
  14. if ($mysqli->affected_rows > 0) {
  15. echo '成功更新了 ' . $mysqli->affected_rows . ' 条记录';
  16. } else {
  17. echo '没有更新任何记录';
  18. }
  19. } else {
  20. die('更新失败'. $mysqli->errno . ' : ' . $mysqli->error);
  21. }
  22. // 3. 关闭连接
  23. // 释放结果集
  24. $mysqli->close();

delete.php

  1. <?php
  2. // 删除操作
  3. // 1. 连接数据库
  4. require 'connect.php';
  5. // 2. 操作数据库
  6. $sql = "DELETE FROM `goods` WHERE `id` =" . $_GET['id'];
  7. if ($mysqli->query($sql)) {
  8. if ($mysqli->affected_rows > 0) {
  9. echo '成功删除了 id=' .$_GET['id'] . ' 的记录';
  10. } else {
  11. echo '没有删除任何记录';
  12. }
  13. } else {
  14. die('删除失败'. $mysqli->errno . ' : ' . $mysqli->error);
  15. }
  16. // 3. 关闭连接
  17. $mysqli->close();

课程学习小结

在老师的直播讲解之后,由通过回看视频进行理解消化,MySQLi在实际项目中还是有一定的用途,值得花一定时间了解。
在修改代码调试的时候,遇到不少问题,如数据无法读取显示等,通过在学习群里提问寻求帮助以及自己重新检查代码的发现细微差别之处等方式予以解决,可见,学习需要理解+熟练,同时编程语言的规范必须严格遵守,稍有差异吗,哪怕是一个小小标点符号的错误,都会影响整个程序的顺利运行,这次的实践中这一点又加深了体会,很有裨益。通过这两次的学习,终于实现了从数据库中获取数据并呈现在页面上,有种全身经络打通的感觉。

Correcting teacher:天蓬老师天蓬老师

Correction status:qualified

Teacher's comments:编程直播非常具有挑战性, 因为一个字母,哪怕是大小写, 一个标点都有可能让整个代码挂掉不能运行, 所以你在编程时遇到这些bug是正常, 写得多了就能确保一遍过了
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post