0

0

PHP mysqli 扩展库(面向对象/数据库操作封装/事务控制/预编译),mysqli面向对象

php中文网

php中文网

发布时间:2016-06-17 08:51:57

|

1274人浏览过

|

来源于php中文网

原创

PHP mysqli 扩展库(面向对象/数据库操作封装/事务控制/预编译),mysqli面向对象

 

1、和mysql扩展库的区别:

     (1   安全性、稳定性更高

     (2  提供了面向对象和面向过程两种风格

 

立即学习PHP免费学习笔记(深入)”;

2、php.ini  中的  extension=php_mysqli.dll 解除封印

3、面向对象:查询列表

 

 1 <?php
 2 
 3   //mysqli &#25805;&#20316;&#25968;&#25454;&#65288;&#38754;&#21521;&#23545;&#35937;&#39118;&#26684;&#65289;
 4   
 5   #1&#12289;&#21019;&#24314;Mysql&#23545;&#35937;
 6   
 7   $mysqli=new MySQLi("127.0.0.1","root","daomul","test");
 8   if(!$mysqli)
 9   {
10        die("&#36830;&#25509;&#22833;&#36133;&#65281;".$mysqli->connect_error);
11   }
12   
13   #2&#12289;&#25805;&#20316;&#25968;&#25454;&#24211;
14   
15   $sql="select * from user1";
16   $res=$mysqli->query($sql);
17   #3&#12289;&#22788;&#29702;&#32467;&#26524;
18   
19   while($row=$res->fetch_row())
20   {
21       foreach($row as $key=> $val)
22       {
23           echo "-- $val";
24       }
25       echo "<br/>";
26   }
27   #4&#12289;&#20851;&#38381;&#36164;&#28304;
28   $res->free();//&#37322;&#25918;&#20869;&#23384;
29   $mysqli->close();//&#20851;&#38381;&#36830;&#25509;
30   
31 ?>

4、面向对象:封装类后实现

  4.1 Sqliconnect.class.php 

 1 <?php
 2 
 3    Class Sqliconnect
 4    {
 5         private $mysqli;
 6         private static $host="127.0.0.1";
 7         private static $root="root";
 8         private static $password="daomul";
 9         private static $db="test";
10         
11         function __construct()
12         {
13              $this->mysqli=new MySQLi(self::$host,self::$root,self::$password,self::$db);
14              if(!$this->mysqli)
15              {
16                    die("&#25968;&#25454;&#24211;&#36830;&#25509;&#22833;&#36133;&#65281;".$this->mysqli->connect_error);
17              }
18              
19              $this->mysqli->query("set names utf8");
20         }
21         
22         //&#26597;&#35810;&#25805;&#20316;
23         public function excute_dql($sql)
24         {
25               $res=$this->mysqli->query($sql) or die("&#25968;&#25454;&#26597;&#35810;&#22833;&#36133;".$this->mysqli->error);
26               return $res;
27               
28         }
29         
30         //&#22686;&#21024;&#25913;&#25805;&#20316;
31         public function excute_dml($sql)
32         {
33               $res=$this->mysqli->query($sql) or die("&#25968;&#25454;&#25805;&#20316;&#22833;&#36133;".$this->mysqli->error);
34               if(!$res)
35               {
36                    echo "&#25968;&#25454;&#25805;&#20316;&#22833;&#36133;";
37               }
38               else
39               {
40                    if($this->mysqli->affected_rows>0)
41                    {
42                          echo "&#25805;&#20316;&#25104;&#21151;&#65281;";
43                    }
44                    else
45                    {
46                         echo "0&#34892;&#25968;&#25454;&#21463;&#24433;&#21709;&#65281;";
47                    }
48               }
49         }
50         
51    }
52 ?>

 

  4.2 调用页面startsqli.php

 

 1 <?php
 2 
 3   //mysqli &#25805;&#20316;&#25968;&#25454;&#65288;&#38754;&#21521;&#23545;&#35937;&#39118;&#26684;&#65289;
 4   
 5   
 6   require_once "Sqliconnect.class.php";
 7   
 8   $Sqliconnect=new Sqliconnect();
 9   
10   //$sql="insert into user1(name,password,email,age) values('&#24093;&#37117;',md5('gg'),'sd@sohu.com',23)";
11   //$sql="delete from user1 where id=11";
12   //$res=$Sqliconnect->excute_dml($sql);
13   
14   $sql="select name from user1;";
15   $res=$Sqliconnect->excute_dql($sql);
16   while($row=$)
17   
18   $res->free();
19 ?>

 

 

立即学习PHP免费学习笔记(深入)”;

5、同时执行多条数据库语句 multiQuery.php

 

 1 <?php
 2 
 3   //mysqli &#25805;&#20316;&#25968;&#25454;&#65288;&#38754;&#21521;&#23545;&#35937;&#39118;&#26684;&#65289;
 4   
 5   #1&#12289;&#21019;&#24314;Mysql&#23545;&#35937;
 6   
 7   $mysqli=new MySQLi("127.0.0.1","root","daomul","test");
 8   if(!$mysqli)
 9   {
10        die("&#36830;&#25509;&#22833;&#36133;&#65281;".$mysqli->connect_error);
11   }
12   
13   #2&#12289;&#25805;&#20316;&#25968;&#25454;&#24211;
14   
15   $sqls="select * from user1;";
16   $sqls.="select * from user1";
17   
18   #3&#12289;&#22788;&#29702;&#32467;&#26524;
19   
20   if($res=$mysqli->multi_query($sqls))
21   {
22        echo "211";
23      do 
24      {
25           //&#20174;mysqli&#36830;&#32493;&#21462;&#20986;&#31532;&#19968;&#20010;&#32467;&#26524;&#38598;
26           $result=$mysqli->store_result();
27           
28           //&#26174;&#31034;mysqli result&#23545;&#35937;
29           while($row=$result->fetch_row())
30           {
31             foreach($row as $key=> $val)
32             {
33                 echo "-- $val";
34             }
35            echo "<br/>";
36          }
37          
38        $result->free();//&#21450;&#26102;&#37322;&#25918;&#24403;&#21069;&#32467;&#26524;&#38598;&#65292;&#24182;&#36827;&#20837;&#19979;&#19968;&#32467;&#26524;&#38598;
39          
40          //&#21028;&#26029;&#26159;&#21542;&#26377;&#19979;&#19968;&#20010;&#32467;&#26524;&#38598;
41          if(!$mysqli->more_results())
42          {
43            break;
44          }
45        echo "<br/>************&#26032;&#30340;&#32467;&#26524;&#38598;**************";
46        
47      }while($mysqli->next_result());
48  }
49  
50   #4&#12289;&#20851;&#38381;&#36164;&#28304;
51   $mysqli->close();//&#20851;&#38381;&#36830;&#25509;  
52   
53   
54 ?>

 

 

立即学习PHP免费学习笔记(深入)”;

6、事务控制

 

 1 <?php
 2 
 3   //mysqli &#25805;&#20316;&#25968;&#25454;&#65288;&#38754;&#21521;&#23545;&#35937;&#39118;&#26684;&#65289;
 4   
 5  
 6    // &#25968;&#25454;&#24211; &#65306;create table account(id int primary key,balance float);
 7    
 8   $mysqli=new MySQLi("127.0.0.1","root","daomul","test");
 9   if(!$mysqli)
10   {
11        die("&#25968;&#25454;&#24211;&#36830;&#25509;&#22833;&#36133;&#65281;".$mysqli->connect_error);
12   }
13   //&#23558;&#25552;&#20132;&#35774;&#20026;false
14   $mysqli->autocommit(false);
15   
16   $sql1="update account set balance=balance+1 where id=1;";//&#27809;&#38169;&#30340;&#35821;&#21477;
17   $sql2="update accounterror2 set balance=balance-1 where id=2";//&#26377;&#38169;&#30340;&#35821;&#21477;
18   
19   $res1=$mysqli->query($sql1);
20   $res2=$mysqli->query($sql2);
21   
22   if(!$res1||!$res2)
23   {
24       //&#22238;&#28378;&#65306;&#20854;&#20013;&#19968;&#20010;&#19981;&#25104;&#21151;&#21363;&#22238;&#28378;&#19981;&#25552;&#20132;
25        echo "&#26377;&#38169;&#65292;&#22238;&#28378;&#65292;&#35831;&#37325;&#26032;&#25552;&#20132;&#65281;";
26        $mysqli->rollback();//die("&#25805;&#20316;&#22833;&#36133;&#65281;".$mysqli->error);
27   }
28   else
29   {
30       //&#25152;&#26377;&#22343;&#25104;&#21151;&#21017;&#25552;&#20132;
31        echo "&#25152;&#26377;&#25552;&#20132;&#25104;&#21151;&#65281;";
32        $mysqli->commit();
33   }
34   
35   $mysqli->close();
36   /* 
37     1&#12289; start transaction; &#24320;&#21551;&#20107;&#21153;
38     2&#12289;svaepoint a;    &#20570;&#20445;&#23384;&#28857;
39     3&#12289;&#25191;&#34892;&#25805;&#20316;1; 
40     4&#12289; svaepoint b;
41     5&#12289;&#25191;&#34892;&#25805;&#20316;2;
42     ...
43     6&#12289;rollback to a/b; &#22238;&#28378;&#25110;&#32773;&#26159;&#25552;&#20132;
44     7&#12289;commit 
45     
46     &#20107;&#21153;&#25511;&#21046;&#29305;&#28857;acid  &#21407;&#23376;&#24615;/&#19968;&#33268;&#24615;/&#38548;&#31163;&#24615;/&#25345;&#20037;&#24615;
47    */
48 ?>

 

7、预处理技术

传声港
传声港

AI驱动的综合媒体服务平台,提供 “媒体发稿 + 自媒体宣发 + 效果监测” 一站式服务

下载

  主要在连接和编译过程精简,还可以SQL防止注入

 7.1 预编译插入多个数据

 

立即学习PHP免费学习笔记(深入)”;

 

 1 <?php
 2 
 3   //mysqli &#39044;&#32534;&#35793;&#28436;&#31034;
 4   
 5   #1&#12289;&#21019;&#24314;mysqli&#23545;&#35937;
 6   $mysqli=new MySQLi("127.0.0.1","root","daomul","test");
 7   if(!$mysqli)
 8   {
 9        die("&#25968;&#25454;&#24211;&#36830;&#25509;&#22833;&#36133;&#65281;".$mysqli->connect_error);
10   }
11   
12   #2&#12289;&#21019;&#24314;&#39044;&#32534;&#35793;&#23545;&#35937;
13   $sql="insert into user1(name,password,email,age) values(?,?,?,?);";//&#26242;&#26102;&#19981;&#36171;&#20540;&#65292;&#29992;&#38382;&#21495;&#20195;&#26367;
14   $stmt=$mysqli->prepare($sql) or die($mysqli->error);
15  
16   /********************************&#21487;&#37325;&#22797;&#25191;&#34892;&#26102;&#38656;&#35201;&#30340;&#20195;&#30721;start*********************************/
17   #3&#12289;&#32465;&#23450;&#21442;&#25968;
18   $name='&#23567;&#26126;5';
19   $password='34f';
20   $email='ssd@qq.com';
21   $age='1';
22   
23   #4&#12289;&#21442;&#25968;&#36171;&#20540;&#65288;&#31532;&#19968;&#20010;&#21442;&#25968;&#25351;&#20195;&#21442;&#25968;&#30340;&#31867;&#22411;&#32553;&#20889;&#65292;string-s,int-i,double-d,bool-b
24   $stmt->bind_param("sssi",$name,$password,$email,$age);
25   
26   #5&#12289;&#25191;&#34892;&#20195;&#30721;&#65288;&#36820;&#22238;&#24067;&#23572;&#31867;&#22411;&#65289;
27   $flag=$stmt->execute();
28   
29  /********************************&#21487;&#37325;&#22797;&#25191;&#34892;&#26102;&#38656;&#35201;&#30340;&#20195;&#30721; end************************************/
30   
31   #6&#12289;&#32467;&#26524;&#20197;&#21450;&#37322;&#25918;
32   
33   if(!$flag)
34   {
35       die("&#25805;&#20316;&#22833;&#36133;".$stmt->error);
36   }
37   else
38   {
39       echo "&#25805;&#20316;&#25104;&#21151;&#65281;";
40   }
41   
42   $mysqli->close();
43   
44  
45 ?>

 

  7.2 预编译查询多个数据

 

 1 <?php
 2 
 3   //mysqli &#39044;&#32534;&#35793;&#28436;&#31034;
 4   
 5   #1&#12289;&#21019;&#24314;mysqli&#23545;&#35937;
 6   $mysqli=new MySQLi("127.0.0.1","root","daomul","test");
 7   if(!$mysqli)
 8   {
 9        die("&#25968;&#25454;&#24211;&#36830;&#25509;&#22833;&#36133;&#65281;".$mysqli->connect_error);
10   }
11   
12    /********************************&#21487;&#37325;&#22797;&#25191;&#34892;&#26102;&#38656;&#35201;&#30340;&#20195;&#30721; start*******************************/
13  
14   #2&#12289;&#21019;&#24314;&#39044;&#32534;&#35793;&#23545;&#35937;
15   $sql="select id,name,email from user1 where id>?;";//id,name,email&#21644;&#21518;&#38754;&#30340;&#32467;&#26524;&#38598;bind_result()&#23545;&#24212;
16   $stmt=$mysqli->prepare($sql) or die($mysqli->error);
17  
18   #3&#12289;&#32465;&#23450;&#21442;&#25968;
19   $id=5;
20   
21   #4&#12289;&#21442;&#25968;&#36171;&#20540;&#65288;&#31532;&#19968;&#20010;&#21442;&#25968;&#25351;&#20195;&#21442;&#25968;&#30340;&#31867;&#22411;&#32553;&#20889;&#65292;string-s,int-i,double-d,bool-b
22   $stmt->bind_param("i",$id);//&#32465;&#23450;&#21442;&#25968;
23   $stmt->bind_result($id,$name,$email);//&#32465;&#23450;&#32467;&#26524;&#38598;
24   
25   #5&#12289;&#25191;&#34892;&#20195;&#30721;&#65288;&#36820;&#22238;&#24067;&#23572;&#31867;&#22411;&#65289;
26   $stmt->execute();
27   
28   #6&#12289;&#21462;&#20986;&#32467;&#26524;&#38598;&#26174;&#31034;
29   while($stmt->fetch())
30   {
31       echo "<br/>$id--$name--$email";
32   }
33   
34   /********************************&#21487;&#37325;&#22797;&#25191;&#34892;&#26102;&#38656;&#35201;&#30340;&#20195;&#30721; end*******************************/
35   
36   #7&#12289;&#32467;&#26524;&#20197;&#21450;&#37322;&#25918;
37   
38   //&#37322;&#25918;&#32467;&#26524;
39   $stmt->free_result();
40   //&#20851;&#38381;&#39044;&#32534;&#35793;&#35821;&#21477;
41   $stmt->close();
42   //&#20851;&#38381;&#25968;&#25454;&#24211;&#36830;&#25509;
43   $mysqli->close();
44   
45  
46 ?>

 

 

立即学习PHP免费学习笔记(深入)”;

8、其他函数

    (1  获取行数和列数  num_rows   field_count

    (2  获取结果集的一列 :表头 例如

              $result=$mysqli->query();

              $result->fetch_field();

    (3 取出数据

             $row=$result->fetch_row(); //获得每一行数据

             再通过 foreach($row as $val){} 取出每一个数据

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

2

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

36

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

4

2026.02.12

Next.js全栈开发与SSR服务端渲染实战
Next.js全栈开发与SSR服务端渲染实战

本专题系统讲解 Next.js 框架在现代全栈开发中的应用,重点解析 SSR、SSG 与 ISR 渲染模式的原理与差异。内容涵盖路由系统、API Routes、数据获取策略、性能优化以及部署实践。通过完整项目示例,帮助开发者掌握高性能 SEO 友好的 React 全栈开发方案。

1

2026.02.12

Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

22

2026.02.12

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

254

2026.02.11

Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析
Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析

本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。

775

2026.02.11

虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法
虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法

本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。

95

2026.02.11

Docker容器化部署与DevOps实践
Docker容器化部署与DevOps实践

本专题面向后端与运维开发者,系统讲解 Docker 容器化技术在实际项目中的应用。内容涵盖 Docker 镜像构建、容器运行机制、Docker Compose 多服务编排,以及在 DevOps 流程中的持续集成与持续部署实践。通过真实场景演示,帮助开发者实现应用的快速部署、环境一致性与运维自动化。

7

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.9万人学习

Django 教程
Django 教程

共28课时 | 4.2万人学习

Excel 教程
Excel 教程

共162课时 | 16.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号