php+mysqli预处理技术实现添加、修改及删除多条数据的方法


Posted in PHP onJanuary 30, 2015

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

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
如何在PHP中使用Oracle数据库(5)
Oct 09 PHP
mysql 字段类型说明
Apr 27 PHP
PHPMailer邮件类利用smtp.163.com发送邮件方法
Sep 11 PHP
PHP 常用函数库和一些实用小技巧
Jan 01 PHP
php is_file 判断给定文件名是否为一个正常的文件
May 10 PHP
使用PHP实现二分查找算法代码分享
Jun 24 PHP
PHP详解ASCII码对照表与字符转换
Dec 05 PHP
php lcg_value与mt_rand生成0~1随机小数的效果对比分析
Apr 05 PHP
什么是PHP文件?如何打开PHP文件?
Jun 27 PHP
如何修改Laravel中url()函数生成URL的根地址
Aug 11 PHP
PHP实现对图片的反色处理功能【测试可用】
Feb 01 PHP
PHP操作Redis数据库常用方法示例
Aug 25 PHP
php+xml结合Ajax实现点赞功能完整实例
Jan 30 #PHP
PHP速成大法
Jan 30 #PHP
php+mysql结合Ajax实现点赞功能完整实例
Jan 30 #PHP
PHP制作百度词典查词采集器
Jan 29 #PHP
php+mysqli事务控制实现银行转账实例
Jan 29 #PHP
php+mysqli批量查询多张表数据的方法
Jan 29 #PHP
php+mysqli实现批量执行插入、更新及删除数据的方法
Jan 29 #PHP
You might like
在PHP3中实现SESSION的功能(一)
2006/10/09 PHP
php preg_filter执行一个正则表达式搜索和替换
2012/02/27 PHP
php简单smarty入门程序实例
2015/06/11 PHP
PHP CURL使用详解
2019/03/21 PHP
json简单介绍
2008/06/10 Javascript
深入理解JavaScript系列(6):S.O.L.I.D五大原则之单一职责SRP
2012/01/15 Javascript
基于jquery的时间段实现代码
2012/08/02 Javascript
Javascript 数组排序详解
2014/10/22 Javascript
jQuery插件ajaxFileUpload实现异步上传文件效果
2015/04/14 Javascript
JS实现简单的图书馆享元模式实例
2015/06/30 Javascript
基于jquery实现智能表单验证操作
2016/05/09 Javascript
node.js 和HTML5开发本地桌面应用程序
2016/12/13 Javascript
AngularJS基于ui-route实现深层路由的方法【路由嵌套】
2016/12/14 Javascript
详解vue+vueRouter+webpack的简单实例
2017/06/17 Javascript
Vue resource中的GET与POST请求的实例代码
2017/07/21 Javascript
基于node.js之调试器详解
2017/08/22 Javascript
webpack-dev-server远程访问配置方法
2018/02/22 Javascript
vue+iview动态渲染表格详解
2019/03/19 Javascript
angular共享依赖的解决方案分享
2020/10/15 Javascript
vue 插槽简介及使用示例
2020/11/19 Vue.js
python 把数据 json格式输出的实例代码
2016/10/31 Python
老生常谈Python序列化和反序列化
2017/06/28 Python
matplotlib绘制鼠标的十字光标的实现(内置方式)
2021/01/06 Python
Python try except else使用详解
2021/01/12 Python
美国知名生活购物网站:Goop
2017/11/03 全球购物
美国相机和电子产品零售商:Beach Camera
2020/11/26 全球购物
网络工程与软件技术毕业生自荐信
2013/09/24 职场文书
2014年上半年工作自我评价
2014/01/18 职场文书
甜品店创业计划书
2014/09/21 职场文书
2014年新农村建设工作总结
2014/12/01 职场文书
学校德育工作总结2015
2015/05/11 职场文书
Mysql - 常用函数 每天积极向上
2021/04/05 MySQL
使用react-virtualized实现图片动态高度长列表的问题
2021/05/28 Javascript
python利用while求100内的整数和方式
2021/11/07 Python
Mysql中常用的join连接方式
2022/05/11 MySQL
使用CSS实现音波加载效果
2023/05/07 HTML / CSS