PHP-Mysqli扩展库的预编译
(1)预编译的好处
假如要执行100条类似的sql语句,每一次执行,在MySQL端都会进行一次编译,效率很低。提高效率的方法就是--减少编译的次数。
先制造一个sql语句的模板,在MySQL端预先编译好,之后每次只需要传递数据即可。
除了提高效率之外,预编译还可以防止sql注入。
(2)dml语句的预编译
以向一个表中插入数据为例。表结构如下:
+----------+----------------------------+
| Field | Type |
+----------+----------------------------+
| id | int(11) |
| name | varchar(20) |
| height | float(5,2) |
| gender | enum('male','female') |
| class_id | int(11) |
+----------+----------------------------+
// dml语句的预编译
// 1.连接数据库
$mysqli = new MySQLi('localhost','root','root','lianxi');
if(mysqli_connect_errno()){
echo '连接失败 '.$mysqli->connect_error;
}
$mysqli->query('set names utf8');
// 2.进行预编译
// 问号是占位符
$sql = 'insert into student values (?,?,?,?,?)';
// 通过MySQLi类的prepare()方法对sql模板进行编译,返回一个MySQLi_STMT类对象
$stmt = $mysqli->prepare($sql) or die($mysqli->connect_error);
// 利用MySQLi_STMT类中的bind_param()方法绑定参数。第一个参数表示各个字段的类型,i(int)、s(string)、d(double)
$stmt->bind_param('isdii',$id,$name,$height,$gender,$classId);
// 3.利用MySQLi_STMT类中的execute()方法插入数据
$id = null;
$name = 'Mildred';
$height = 165.00;
$gender = 2;
$classId = 12;
$stmt->execute() or die($stmt->error);
// 继续插入数据
$id = null;
$name = 'Shaw';
$height = 174.50;
$gender = 1;
$classId = 11;
$stmt->execute() or die($stmt->error); // 关闭连接
$stmt->close();
$mysqli->close();
(3)dql语句的预编译
和dml语句不同的地方在于,除了要绑定参数,还需要绑定结果集
// dql语句的预编译
// 1.连接数据库
$mysqli = new MySQLi('localhost','root','root','lianxi');
if(mysqli_connect_error()){
die('连接失败 '.$mysqli->connect_error);
}
$mysqli->query('set names utf8');
// 2.编译sql语句
$sql = 'select * from student where id>?';
$stmt = $mysqli->prepare($sql) or die($mysqli->error);
// 3.绑定参数
$stmt->bind_param('i',$id);
// 4.绑定结果集
$stmt->bind_result($id,$name,$height,$gender,$classId);
// 5.执行
$id = 2;
$stmt->execute();
// 6.利用MySQLi_STMT类中的fetch()方法,通过循环得到查询的数据
while($stmt->fetch()){
echo $id.'--'.$name.'--'.$height.'--'.$gender.'--'.$classId;
echo '<br>';
}
// 7.关闭连接
$stmt->free_result();
$stmt->close();
$mysqli->close();
PHP-Mysqli扩展库的预编译的更多相关文章
- php mysqli扩展库之预处理操作
分享下php使用mysqli扩展库进行预处理操作的二个例子,有意研究mysqli用法的朋友,可以参考学习下,一定会有所帮助的. 例1.使用mysqli扩展库的预处理技术 mysqli stmt 向数据 ...
- PHP使用mysqli扩展库实现增删改查(面向对象版)
mysqli扩展库是mysql扩展库的改进版本,在mysql扩展库的基础上提高了稳定性和效率,mysqli扩展库有两套东西,一套就是面向过程的mysqli另一套是面向对象的mysqli.操作方式大体和 ...
- mysqli扩展库操作mysql数据库
配置环境 配置php.ini文件让php支持mysqli扩展库 extension=php_mysqli.dll 建库建表 详见博客 “mysql扩展库操作mysql数据库” 查询数据库 <?p ...
- 【小结】有关mysql扩展库和mysqli扩展库的crud操作封装
现阶段php如果要操作mysql数据库 php给我们提供了3套库 1.mysql扩展库 面向过程操作 2.mysqli扩展库 面向对象操作和面向过程操作并存 安全性和效率高于mysql扩展库 ...
- 使用php的mysqli扩展库操作mysql数据库
简单介绍mysqli: 1.mysqli(mysql improve mysql扩展库的增强版) mysql扩展库和mysqli扩展库的区别 1.mysqli的稳定性 安全性 和 执行效率有所提高 ...
- mysqli扩展库应用---程序范例
通过mysqli扩展库对用户表user1进行增删改查操作,用户表user1结构如下: 1,建立数据库操作类库mysqliTool.class.php,代码如下: <?php class mysq ...
- php数据库编程---mysqli扩展库
1,mysqli扩展库允许我们访问MySQL数据库,并对MySql数据库进行curd操作.Mysqli扩展库比mysql扩展库加强了. 2,mysqli扩展库和mysql扩展库的比较 (1) mysq ...
- PHP mysqli 扩展库(面向对象/数据库操作封装/事务控制/预编译)
1.和mysql扩展库的区别: (1 安全性.稳定性更高 (2 提供了面向对象和面向过程两种风格 2.php.ini 中的 extension=php_mysqli.dll 解除封印 3.面 ...
- mysqli扩展库的预处理技术 mysqli stmt
//预编译演示 //1,创建mysqli对象 $mysqli=new mysqli("localhost","root",""," ...
随机推荐
- 又是一天String
(1) Length of Last Word 解题思路:使用length记录最后一个单词的长度.从最后一个字符开始,如果是空字符,length不变.如果不是空字符,length++,直到再次遇到空字 ...
- android_demo之生成颜色布局
前面学习了动态生成表格,不单单是要动态生成控件,也同时生成一个事件. 接下来用个小小栗子去了解这个知识点. <LinearLayout xmlns:android="http://sc ...
- C#连接Sql Serve数据库及增,删,改操作
一:连接. string sqlconn = "server=主机名;database=数据名;integrated security=true" //integrated sec ...
- web测试安全性常见问题
web测试安全性常见问题 一. 登录账号明文传输 1. 问题一:登录账号密码或者修改密码明文传输 现象:目前物流对内的java系统基本上都是 ...
- jQuery小节
jQuery 语法 jQuery 选择器 在前面的章节中,我们展示了一些有关如何选取 HTML 元素的实例. 关键点是学习 jQuery 选择器是如何准确地选取您希望应用效果的元素. jQuery 元 ...
- Winform GDI+ 相关资料
在Visual Studio 2010中定义GDI+自定义控件——自定义控件介绍 http://www.cnblogs.com/zhangdong/archive/2010/05/20/1740177 ...
- java序列化深拷贝
java深拷贝 序列化和反序列化合成在一起的方法CloneUtils import java.io.ByteArrayInputStream; import java.io.ByteArrayOutp ...
- .style, .getComputedStyle(),.currentStyle区别
1)style只能获取行间样式(写在标签里面的):能读能写 2)currentStyle是专属ie的属性,区别他返回的是最终样式 及包括行间和外链css 3)getComputedStyle是一个可以 ...
- SQL Server 查询表备注信息的语句
--name 字段名称--user_type_id --max_length 最大长度--is_nullable 是否允许空--remark 描述SELECT c.name, c.user_ty ...
- discuz!安装遇到问题的解决方案
正常的安装步骤好多地方都有写过了,我安装的时候遇到问题百度翻了个遍也没有找到,现在问题已经解决了,发出了分享一下! 进入第三步创建数据库的时候提示:由于目标计算机积极拒绝,无法连接. 打开phpmya ...