现在的位置: 网页制作教程网站制作经验 >正文
php网上学习

php向mysql发送多条数据 采用预处理技术实现数据库查询和添加

发表于2017/4/22 网站制作经验 0条评论 ⁄ 热度 1,865℃

本文介绍了php+mysqli预处理技术的原理及使用技巧,并通过实例演示预处理技术实现向数据库添加多条数据的方法,可有效提高程序运行效率,非常具有实用价值。

什么是预处理技术?

举个例子:假设要向数据库添加100个用户,按常规思路,就是向数据库发送100个执行请求,此时,按照 mysql 数据库的工作原理,它需要对每一条执行语句进行编译(这里就有100次)。所以,这里的效率是非常低的。

预处理技术的作用,就是减少编译的次数和时间,以提高效率。当 php 程序第一次发送sql 语句时,mysql 数据库就编译好了后面99次,php只要发送数据过去即可,不需要再进行编译。

本实例主要用到了prepare方法,mysqli对prepare的支持对于大访问量的网站是很有好处的,它极大地降低了系统开销,而且保证了创建查询的稳定性和安全性。

php查询mysql数据库prepare语句用法:

<?php
$mysql = new mysqli('localhost', 'root', 'root', 'databaseName') or die('There was a problem connecting to the database');
$stmt = $mysql->prepare('SELECT id, title, content FROM tableName');
$stmt->execute();
$stmt->bind_result($id, $title, $content);
while($row = $stmt->fetch()) : 
?>
<h2> <?php echo $title; ?> </h2>
<p> <?php echo $content; ?> </p>
<?php endwhile; ?>

php+mysqli预处理技术向数据库添加多条数据

<?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 "成功";
}
?>
  • 暂无评论