mysqli预处理和事务处理
|
1 |
应用环境 |
|
|
mysqli预处理功能(大量数据处理时使用) |
||
|
2 |
步骤 |
|
|
a)mysqli连接数据库 |
$mysqli = new mysqli('localhost','root','root','chuanzhi'); |
|
|
b)设置编码 |
$mysqli->set_charset('gb2312'); |
|
|
c)发送query语句 |
使用$mysqli->prepare($query)这个方法表示是预处理,如果涉及到取值,必须指定查询字段 $query = "select id,proName,proClass,proPrice from product where id>?"; $stmt = $mysqli->prepare($query); |
|
|
d)提供条件 |
比如上句用了?作为不确定的值,就需要指定 $stmt->bind_param('i', $id); 用变量绑定?表示的值,i表示整型,d表示浮点型,b代表二进制,s代表其它的所有 $id='1'; 指定变量的值 $stmt->execute(); 发送变量,此时服务器的语句已经完整了 |
|
|
e)从sql服务器中取回结果 |
预处理语句会将结果集保存在sql开辟的内存中,php开辟的内存无法直接使用(count是php函数,不是sql函数,无法直接与sql内存交互),默认情况是每次执行fetch()会从sql内存中取出一行,但是不使用store_result()就无法获取行数.当然如果你的结果只有一行,可以无视这一句.请记住:在mysqli预处理中取出数据,只能使用fetch()这是因为mysqli_stmt类并没有其它取值方法 $stmt->store_result();//如果用变量接收的话,会发现成功了显示1,否则显示0 |
|
|
f)获取结果集行数 |
$count = $stmt->num_rows(); |
|
|
g)绑定结果集需要输出的字段 |
$stmt->bind_result($id,$proName,$proClass,$proPrice); 名字无所谓,反正按顺序对应query的字段,变量个数要和query字段个数一致 |
|
|
h)输出结果 |
前面说了,既然要取值,当然前面query指定了查询字段,上句的变量用上了 |
|
|
i) |
你懂的,关闭mysqli链接 |
事务处理
|
1 |
应用环境 |
|
|
对于安全比较在意的时候使用 |
||
|
2 |
步骤 |
|
|
MYSQL中只有INNODB和BDB类型的数据表才能支持事务处理!其他的类型是不支持的! |
||
|
a)连接数据库和设置编码 |
不用说,当然是连接数据库和设置编码了,mysql和mysqli都支持事务处理 |
|
|
b)关闭自动提交 |
$mysqli->autocommit(false);在sql的客户端里面用set autocommit = 0; |
|
|
c)开启事务 |
开启一个事务start transation(mysql中才有这一句,mysqli不需要这一句); |
|
|
d)执行sql语句 |
||
|
e)判断执行结果是否是自己想要的 |
如果是,就提交$mysqli->commit(); 否则,回滚$mysqli->rollback(); |
|
|
f)开启自动提交 |
$mysqli->autocommit(true); //个人认为这句并不是必须的,因为页面执行完,会回到初始状态,也就是自动提交状态 |
|
|
g)关闭数据库连接 |
$mysqli->close(); |
|
mysqli预处理和事务处理的更多相关文章
- php+mysqli预处理技术实现添加、修改及删除多条数据的方法
本文实例讲述了php+mysqli预处理技术实现添加.修改及删除多条数据的方法.分享给大家供大家参考.具体分析如下: 首先来说说为什么要有预处理(预编译)技术?举个例子:假设要向数据库添加100个用户 ...
- PHP 对MySQLI预处理的包装
mysql 类 <?php class Mysql { private static $instance; private $link; private $query; private $stm ...
- mysqli 预处理语句
预处理语句用于执行多个相同的 SQL 语句,并且执行效率更高. <?php // 设置编码格式 header('content-type:text/html;charset=utf-8'); / ...
- php mysqli 预处理操作数据库
用到的SQL表 CREATE TABLE `student_01` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) CHARAC ...
- php mysqli扩展之预处理
在前一篇 mysqli基础知识中谈到mysqli的安装及基础操作(主要是单条sql语句的查询操作),今天介绍的是mysqli中很重要的一个部分:预处理. 在mysqli操作中常常涉及到它的三个主要类: ...
- PHP(Mysqli和PDO)预处理
PHP预处理主要是用来防SQL注入的,开发程序的都明白这样一个道理,不能相信用户的任何输入,如果用户输入问题你没有做相应的安全, 那么:你的程序是很危险的,很容易被攻击的!预处理:只分析两个:mysq ...
- mysqli 操作数据库(转)
从php5.0开始增加mysql(i)支持 , 新加的功能都以对象的形式添加 i表示改进的意思 功能多.效率高.稳定 编译时参数: ./configure --with-mysql=/usr/bin/ ...
- mysqli 操作数据库
从php5.0开始增加mysql(i)支持 , 新加的功能都以对象的形式添加 i表示改进的意思 功能多.效率高.稳定 编译时参数: ./configure --with-mysql=/usr/bin/ ...
- PHP5: mysqli 插入, 查询, 更新和删除 Insert Update Delete Using mysqli (CRUD)
原文: PHP5: mysqli 插入, 查询, 更新和删除 Insert Update Delete Using mysqli (CRUD) PHP 5 及以上版本建议使用以下方式连接 MySQL ...
随机推荐
- js中的浅拷贝和深拷贝
说说最近所学:浅拷贝和深拷贝也叫做浅克隆和深克隆,深浅主要针对的是对象的"深度",常见的对象都是"浅"的,也就是对象里的属性就是单个的属性,而"深&q ...
- andriod GridView
<?xml version="1.0" encoding="UTF-8"?> <GridView xmlns:android="ht ...
- C实现通用数据结构--双向链表
双向链表概述 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继next和直接前驱prev.所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结 ...
- javascript 依次输入自动定焦框
<html> <head> <script type="text/javascript"> function moveNext(object,i ...
- opencms忘记Admin用户登录密码解决方案
不知道现在还有多少人在用opencms: 我今天就是遇到一个问题,很久之前部署的一台opencms服务器,突然忘记密码了,记录下处理方法: 希望对你有帮助: opencms忘记Admin用户登录密码了 ...
- Effective Java 24 Eliminate unchecked warnings
Note Eliminate every unchecked warning that you can. Set<Lark> exaltation = new HashSet(); The ...
- delete_old_backup.bat
在前面forfiles命令批量删除N天前文件 这篇文章里面讲述了如何在SQL Server 2000中使用forfile删除N天前备份文件,但是现在又有新需求: 需求描述:通过数据库维护计划将备份生成 ...
- 烂泥:LVM学习之LVM基础
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 有关LVM的好处我就不在此多介绍了,有空的话自己可以去百度百科中看看.我们在此之进行LVM的相关操作,以及命令的学习. 要想使系统支持LVM,我们必须安 ...
- 记一次Web应用CPU偏高
LZ开发的一个公司内部应用供查询HIVE数据使用.部署上线后总是会出现CPU偏高的情况,而且本地测试很难重现.之前出现几次都是通过直接重启后继续使用,因为是内部使用,重启一下也没有很大影响(当然,每次 ...
- DimDate populate data
日期维度 任何一个数据仓库都应该有一个日期维度. 因为很少有不需要通过日期维度看数据的情况存在. 日期维度的好处是,你可以通过他连接各个事实表,然后在报表端传送报表参数的时候, 直接自动过滤日期维度的 ...