本文实例讲述了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 "成功";
}
?>

  转自:http://www.jb51.net/article/60578.htm

最新文章

  1. 聊聊HTTPS和SSL/TLS协议
  2. SAP的运输功能(转)
  3. *在Win7中安装JDK1.7并配置环境变量
  4. 使用python三方库xlrd解析excel数据
  5. VC用OLE方式读写Excel
  6. Git命令非主流札记
  7. Log4j2 简明教程
  8. instance 怎么获得自己的 Metadata - 每天5分钟玩转 OpenStack(169)
  9. devDependencies和dependencies的版本写法
  10. let const var的区别与作用
  11. nginx反向代理+tomcat域名绑定
  12. tcl实现批量压缩文件夹
  13. Window下安装Scala出现:此时不应有 \scala\bin\..\lib\jline-2.14.5.jar
  14. bitset里面一些函数的用法
  15. 涨知识:equals 和 == 你真的了解吗?
  16. top 命令常用操作
  17. LibreOJ #6001. 「网络流 24 题」太空飞行计划 最大权闭合图
  18. 【C#】使用MySql.Data.dll连接MySQL数据库
  19. docker 入門
  20. WEB入门.五 页面设计简介

热门文章

  1. hdu-3549 Flow Problem---最大流模板题(dinic算法模板)
  2. 【转】Web实时通信之Socket.IO ,真正的兼容ie
  3. 三种序列化方式存取redis的方法
  4. 在docker镜像中加入环境变量
  5. BZOJ1576: [Usaco2009 Jan]安全路经Travel(最短路 并查集)
  6. 【Python学习之九】asyncio—异步IO
  7. mybatis的优缺点及应用场合
  8. makefile学习(1)
  9. POJ 2586 贪心+枚举
  10. DAG上的动态规划——嵌套矩阵问题