经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
PHP连接MySql数据库方法简化版
来源:jb51  时间:2022/7/25 17:15:40  对本文有异议

写这个PHP连接数据库静态工具类之前,是由于当时学习C#的asp.net。老师编写了一个连接数据库的静态工具类,发现使用此类,每次只需要写sql语句,而不再需要进行连接创建,关闭等等。方便其他操作,节约时间。

转眼一年半,如今php课程需要写一个小项目,于是第一件事就是编写一个连接数据库的静态工具类,php和asp.net的语法极其的相似。

在使用此类之前,可以普及两点知识:

PHP中使用静态的调用,不同于其他编程语言,它的静态调用为:

类名::$静态属性

类名::静态方法()

而Java、C#等编程语言都是通过:

类名.静态属性

类名.静态方法()

静态方法的优点:

(1)在代码的任何地方都可以用,不需要实例对象就能访问静态属性或方法;

(2)类的每个实例都可以访问类中定义的静态属性,可以利用静态属性来设置值,该值可以被类的所有对象使用,方便控制数据库参数,连接对象的创建与关闭;

DBHelper.php 静态工具类

  1. <?php
  2. /**该PHP文件为了连接数据库方便
  3. * 为连接数据库提供静态方法
  4. */
  5. header("Content-type: text/html;charset=utf-8");
  6. class DBHelper {
  7. static $sqlName = "127.0.0.1";
  8. static $userName = "root";
  9. static $passWord = "123456";
  10. static $dbName = "test";
  11. //连接数据库
  12. static function dbConn() {
  13. $conn = mysqli_connect(self::$sqlName, self::$userName,
  14. self::$passWord, self::$dbName);
  15. if ($conn == false) {
  16. echo "<script>alert('数据库连接失败')</script>";
  17. }
  18. //设置连接对象编码
  19. mysqli_query($conn, "set names utf8");
  20. return $conn;
  21. }
  22. //查询数据
  23. //param1:查询类型,param2:执行语句
  24. //param1参数类型: 0单个数组,1多个数组。
  25. static function select($state, $mysql):array {
  26. $conn = self::dbConn(); //获得连接对象
  27. $sql = $mysql;
  28. $query = mysqli_query($conn, $sql);
  29. if ($state == 1) {
  30. $result = mysqli_fetch_all($query,MYSQLI_ASSOC);
  31. } else {
  32. $result = mysqli_fetch_assoc($query);
  33. }
  34. // 释放结果集
  35. mysqli_free_result($query);
  36. self::dbClose($conn); //释放连接对象
  37. if ($result == null) { //如果结果为空,则返回空数据集
  38. return array();
  39. }
  40. return $result;
  41. }
  42. //增加、删除、修改数据
  43. //param1:执行类型;param2:执行语句
  44. //param1参数类型:1增加,2修改,3删除。
  45. static function sqlHelper($state, $mysql):int {
  46. $conn = self::dbConn(); //获得连接对象
  47. $sql = $mysql;
  48. $query = mysqli_query($conn, $sql);
  49. //判断状态,做出相应提示。
  50. //$sts = $state==3?"删除":($state==2?"修改":($state==1?"增加":$state));
  51. self::dbClose($conn); //释放连接对象
  52. if ($query){
  53. return 1; //有内容变化
  54. //return $sts."成功";
  55. }
  56. else{
  57. return 0; //无内容变化
  58. //return $sts."失败";
  59. }
  60. }
  61. //关闭连接
  62. static function dbClose($conn) {
  63. $conn ->Close();
  64. }
  65. }
  66. ?>

Test.php 用来测试数据

  1. //查询单个数据
  2. $select = DBHelper ::select(0, "select * from XXX where xx = '$xx'");
  3. //查询多个数据
  4. $selectAll = DBHelper ::select(1,"select * from XXX");
  5. //添加数据
  6. $insert = DBHelper ::sqlHelper(1, "insert into XXX (xx,xx,xx) values ('$xx','$xx','$xx')");
  7. //修改数据
  8. $update = DBHelper ::sqlHelper(2, "update XXX set xx = '$xx',xx = '$xx',xx = '$xx', where xx = '$xx'");
  9. //删除数据
  10. $delete = DBHelper ::sqlHelper(3, "delete from XXX where xx = '$xx'");

前两条测试数据,都是查询,设置的返回参数分别为mysqli_fetch_assoc、mysqli_fetch_all,这两个参数返回的都是array,只不过里面有单个数据或多个数据。

  1. mysqli_fetch_assoc

mysqli_fetch_all:

后三条对应的是增删改,返回的int类型参数,可以判断执行是否成功。

到此这篇关于PHP连接MySql数据库方法简化版的文章就介绍到这了,更多相关PHP连接MySql内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号