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",""," ...
随机推荐
- iOS有用的三方库
DKNightVersion https://github.com/Draveness/DKNightVersion#podfile 用来为APP添加夜间模式和换肤功能
- Action名称的搜索顺序
假设当前的路径的URL是:http://StrutsDemo01/path1/path2/path3/test.action 步骤1.首先寻找命名空间(namespace)为 /path1/path2 ...
- 转 夕甲甲:孔乙己之 C++ 版
欧欧匹代码的格局,是和别的编程模式不同的:首先要有一个构造函数:基类里只定义了函数的形式,可以随时通过派生增加不同的实现.那些程序员们,每每学会了继承和多态,便可以接一个项目,——这是十年前的事,现在 ...
- order_by_、group_by_、having的用法区别
写于 2012-11-20 22:14 doc文档上. Having 这个是用在聚合函数的用法.当我们在用聚合函数的时候,一般都要用到GROUP BY 先进行分组,然后再进行聚合函数的运算.运算完后 ...
- java io流之BufferReader&BufferedWriter
BufferedReader 由Reader类扩展而来,提供通用的缓冲方式文本读取,而且提供了很实用的readLine,读取一个文本行,从字符输入流中读取文本,缓冲各个字符,从而提供字符.数组和行的高 ...
- 定义/修改列时 NULL
mysql的文档说明: column_definition: col_name type [NOT NULL | NULL] [DEFAULT default_value] [ ...
- flash中网页跳转总结
浏览器中,程序同时跳转两个网页地址,第一个地址不会跳转,只会跳转第二个地址,如果第二个地址做延时,则第一个正常跳转,第二个地址会被拦截: 浏览器中,接口返回事件的函数中不能程序跳转网页地址. 这两条结 ...
- eclipse部署web项目至本地的tomcat但在webapps中找不到
一.发现问题 在eclipse中新建Dynamic Web Project,配置好本地的tomcat并写好代码后选择Run on Server,但运行后发现在tomcat的安装目录下的webapps并 ...
- 最简单的访问google的办法
我用的是猎豹浏览器,在工具下面的猎豹应用市场里面,搜索红杏,安装即可. 打开google产品地址时,如果地址栏里面右边的杏是绿色的,代表正常,如果是红色的,代表不正常. 可能是装了其他代理软件,如Sw ...
- MVC 构建图片/文件选择器 参考其它CMS功能
实现结果,如下 点击选择图片,弹出一个iframe框 顶部默认图片根目录,依次下面是文件列表 底部是选择的文件地址,以及上传新的图片和文件 加载iframe 调用js方法 function initF ...