php+mysqli预处理技术实现添加、修改及删除多条数据的方法
发布:smiling 来源: PHP粉丝网 添加日期:2021-05-09 15:34:47 浏览: 评论:0
这篇文章主要介绍了php+mysqli预处理技术实现添加、修改及删除多条数据的方法,实例分析了mysqli实现预处理的原理及使用技巧,可有效提高程序运行效率,非常具有实用价值,需要的朋友可以参考下,本文实例讲述了php+mysqli预处理技术实现添加、修改及删除多条数据的方法。分享给大家供大家参考。具体分析如下:
首先来说说为什么要有预处理(预编译)技术?举个例子:假设要向数据库添加100个用户,按常规思路,就是向数据库发送100个执行请求,此时,按照 mysql 数据库的工作原理,它需要对每一条执行语句进行编译(这里就有100次)。所以,这里的效率是非常低的。
预处理(预编译)技术的作用,就是减少编译的次数和时间,以提高效果。通过一个案例来说明,预处理(预编译)技术是如何做到的(好吧,先说清楚,当 php 程序第一次发送 sql 语句时,mysql 数据库就编译好,到了后面99次,php只要发送数据过去即可,不需要再进行编译)。
- <?php
- //1、创建数据库连接对象
- $mysqli = new MySQLi("localhost","root","123456","liuyan");
- if($mysqli->connect_error){
- die($mysqli->connect_error);
- }
- $mysqli->query("set names 'GBK'");
- //2、创建预编译对象
- $sql = "insert into account(id,balance) values(?,?)";
- //这里用 ? 来代替要插入的数据值
- $stmt = $mysqli->prepare($sql);
- //返回一个statement对象,对象中的方法见手册 MySQLi_STMT
- //3、绑定参数(需要插入的数据),并执行
- $id=null;//这里我数据库设置成了 primary key auto_increment
- $balance=100.5;
- $stmt->bind_param("id",$id,$balance);
- //绑定参数,返回值为布尔值。"if"按顺序代表插入数据的数据类型
- //这里$id为int,用i表示,$balance为float型,用d表示,具体见手册
- $res = $stmt->execute();//执行语句,返回值为布尔类型
- //4、判断是否执行成功
- if(!$res){
- echo "数据插入失败,balance值为:".$balance;
- }else{
- echo "成功";
- }
- /*
- *****插入第二条数据
- */
- //3、绑定参数(需要插入的数据),并执行
- $id=null;//这里我数据库设置成了 primary key auto_increment
- $balance=400.3;
- $stmt->bind_param("id",$id,$balance);
- //绑定参数,返回值为布尔值。"if"按顺序代表插入数据的数据类型
- //这里$id为int,用i表示,$balance为float型,用d表示。
- $res = $stmt->execute();//执行语句,返回值为布尔类型
- //4、判断是否执行成功
- if(!$res){
- echo "数据插入失败,balance值为:".$balance;
- }else{
- echo "成功";
- }
- ?>
Tags: php+mysqli预处理 php+mysqli修改
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)