• 提出问题

现在需要向mysql数据库中添加100个用户,请问如何实现?

方法一:for循环100次

方法二:使用批量添加

  $sqls="insert xxx";

  $sqls.="insert xxx";

  ......

  $mysqli->multi_query($sqls);

显然,上述方法效率低。

提高效率的方法一般有:

1、减少数据库连接次数;2、减少数据库编译时间。

所以提出方法三:预编译

  • 预编译

注意:预编译和编译都是在数据库完成。

优点:1、效率高,执行速度块;2、安全性高,可以防止sql注入。

  • 案例1

使用预编译的方式向数据库添加三个用户:

 <?php
//需求:使用预编译方式向数据库添加三个用户
//连接数据库
$mysqli=new MySQLi("localhost","root","root","test");
//修改字符集
$mysqli->query("set names utf8");
//创建预编译对象
$sql="insert into user1 (name,password,age,birthday) values (?,?,?,?)";
$mysqli_stmt=$mysqli->prepare($sql); //绑定参数1
$name="zx";
$password="123456";
$age=28;
$birthday="1989-08-08";
//给?赋值,类型和顺序要对应
$mysqli_stmt->bind_param("ssis",$name,$password,$age,$birthday);
//执行
$res1=$mysqli_stmt->execute();
//判断结果
if(!$res1){
die("操作1失败".$mysqli_stmt->error);
echo "<br/>";
}else{
echo "操作1成功<br/>";
} //绑定参数2
$name="zx2";
$password="123456";
$age=28;
$birthday="1989-08-09";
//给?赋值,类型和顺序要对应
$mysqli_stmt->bind_param("ssis",$name,$password,$age,$birthday);
//执行
$res2=$mysqli_stmt->execute();
//判断结果
if(!$res2){
die("操作2失败".$mysqli_stmt->error);
echo "<br/>";
}else{
echo "操作2成功<br/>";
} //绑定参数3
$name="zx3";
$password="123456";
$age=28;
$birthday="1989-08-03";
//给?赋值,类型和顺序要对应
$mysqli_stmt->bind_param("ssis",$name,$password,$age,$birthday);
//执行
$res3=$mysqli_stmt->execute();
//判断结果
if(!$res3){
die("操作3失败".$mysqli_stmt->error);
echo "<br/>";
}else{
echo "操作3成功<br/>";
} //关闭连接
$mysqli->close();
?>

注意:1、程序执行过程中,某个sql语句执行不成功,并不会中断程序执行,会继续向下执行;

2、第二次之后,不用绑定参数也可以,即34、51行可以省略。

结果如下:

  • 案例2

查询数据库中id>?的记录,并在网页显示:

 <?php
//连接数据库
$mysqli=new MySQLi("localhost","root","root","test");
if(mysqli_connect_error()){
die("连接失败".mysqli_connect_error());
}
//修改字符集
$mysqli->query("set names utf8");
//创建预编译对象,查询id>?的记录
$sql="select id,name,age,birthday from user1 where id>?";
$mysqli_stmt=$mysqli->prepare($sql); //绑定参数1
$id=5;
$mysqli_stmt->bind_param("i",$id);
//绑定结果集
$mysqli_stmt->bind_result($id,$name,$age,$birthday);
//执行
$mysqli_stmt->execute();
//取出绑定的值
while($row=$mysqli_stmt->fetch()){
echo "$id--$name--$age--$birthday<br/>";
} echo "***************************************<br/>"; //绑定参数2
$id=8;
//执行
$mysqli_stmt->execute();
//取出绑定的值
while($row=$mysqli_stmt->fetch()){
echo "$id--$name--$age--$birthday<br/>";
} //释放结果
$mysqli_stmt->free_result();
//关闭预编译语句
$mysqli_stmt->close();
//关闭连接
$mysqli->close();
?>

结果如下:

mysqli 扩展库的预处理技术(mysqli_stmt)的更多相关文章

  1. mysqli扩展库的 预处理技术 mysqli stmt

    问题的提出? 现在需要向mysql数据库添加100个用户,请问如何实现? 思路: 使用for循环100次,向数据库中添加100个用户. 使用批量添加 $sql1=”insert xxx”; $ssql ...

  2. mysqli扩展库的预处理技术 mysqli stmt

    //预编译演示 //1,创建mysqli对象 $mysqli=new mysqli("localhost","root",""," ...

  3. php mysqli扩展库之预处理操作

    分享下php使用mysqli扩展库进行预处理操作的二个例子,有意研究mysqli用法的朋友,可以参考学习下,一定会有所帮助的. 例1.使用mysqli扩展库的预处理技术 mysqli stmt 向数据 ...

  4. mysqli扩展库的预处理

    预处理的特点:1.效率高,执行速度快 2.安全性高,可以防止sql注入 $mysqli  中的函数 $stmt=$mysqli->prepare($sql);             预备一条s ...

  5. PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作

    就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi 所生成的预处理语句的.其实操作方式之类也都比较相似,不外 ...

  6. PHP使用mysqli扩展库实现增删改查(面向对象版)

    mysqli扩展库是mysql扩展库的改进版本,在mysql扩展库的基础上提高了稳定性和效率,mysqli扩展库有两套东西,一套就是面向过程的mysqli另一套是面向对象的mysqli.操作方式大体和 ...

  7. mysqli扩展库操作mysql数据库

    配置环境 配置php.ini文件让php支持mysqli扩展库 extension=php_mysqli.dll 建库建表 详见博客 “mysql扩展库操作mysql数据库” 查询数据库 <?p ...

  8. 【小结】有关mysql扩展库和mysqli扩展库的crud操作封装

    现阶段php如果要操作mysql数据库 php给我们提供了3套库 1.mysql扩展库   面向过程操作 2.mysqli扩展库  面向对象操作和面向过程操作并存  安全性和效率高于mysql扩展库 ...

  9. 使用php的mysqli扩展库操作mysql数据库

    简单介绍mysqli: 1.mysqli(mysql improve mysql扩展库的增强版) mysql扩展库和mysqli扩展库的区别 1.mysqli的稳定性  安全性 和 执行效率有所提高 ...

随机推荐

  1. chrmoe debug

    一.右击,点击审查元素 二.打开后,每个tab是干什么用的呢? 三.调试样式 选中Elemes后,右边有个窗口,这里是CSS的样式,可以直接选中元素,并且在这里修改样式.这样调试很方便,效率也很高.当 ...

  2. 14周事情总结-机器人-大数据hadoop

    14周随着考试的进行,其他该准备的事情也在并行的处理着,考试内容这里不赘述了 首先说下,关于机器人大赛的事情,受益颇多,机器人的制作需要机械和电控两方面 昨天参与舵机的测试,遇到的问题:舵机不动 排查 ...

  3. Hadoop与分布式开发

        hadoop上的并行应用程序开发是基于MapReduce编程框架的,MapReduce编程模型的原理是:利用一个输入的key/value对集合来产生一个输出的key/value对集合. Map ...

  4. linux http请求监控工具httpry---官方文档

    原文地址:http://dumpsterventures.com/jason/httpry/ core program httpry is a specialized packet sniffer d ...

  5. <BEA-141281> <unable to get file lock, will retry ...> --reference

    I ran into this error the first time I restarted Weblogic on one of my installs, the only reference ...

  6. redhat系统安装部署

    linux 系统安装部署 1).光盘引导,选择第一项: 2)介质检查,选择skip: 3).欢迎界面,直接下一步: 4).选择安装过程使用的语言,选择“English”; 5).选择键盘布局,不需要修 ...

  7. word ppt excel文档转换成pdf

    1.把word文档转换成pdf (1).添加引用 using Microsoft.Office.Interop.Word; 添加引用 (2).转换方法 /// <summary> /// ...

  8. Android adapter适配器的使用

    说起Adapter的使用,首先想到的就是listview或各种各样的Adapter.下面我们对常用的一些Adapter进行简单的使用讲解. 这是Adapter的关系图: 下面的所有例子均使用同一个布局 ...

  9. c语言对于文本的基本操作

    字符读写函数  :fgetc和fputc 字符串读写函数:fgets和fputs 数据块读写函数:freed和fwrite 格式化读写函数:fscanf和fprinf   1.字符读写: fgetc函 ...

  10. 命令精解之DOS批处理

    前言 最近对于批处理技术的探讨比较热,也有不少好的批处理程序发布,但是如果没有一定的相关知识恐怕不容易看懂和理解这些批处理文件,也就更谈不上自己动手编写了,古语云:“授人以鱼,不如授人以渔.”因为网上 ...