pdo的简单介绍和使用
1,PDO的定义;php data object(php数据对象);
2,连接pdo的相关参数:$dsn、$user、$pass.
其中$dsn="mysql:host=$host;dbname=$dbname";
1)$dsn:数据源,字符串类型 2)$user=数据库连接账户名
3)$pass=数据库连接密码
3,pdo支持的数据库多达12种以上,用于连接不同的数据库;便于项目后期的扩展和数据库更改
4,PDOStatement类的作用:解析结果集,实现预处理,事务处理等特殊功能
5,PDOException类:主要用于捕获pdo异常
6,PDO类:pdo的核心,用于数据库的连接、发送sql语句等
7,关闭pdo的方法:unset($pdo)、$pdo=null;
8, PDO中的执行操作
1)增删改:int PDO::exec(string $statement)
$sql->exec($sql);
执行sql语句并返回受影响的行数
返回最后一条插入的id:$pdo->lastInsertId();
2)查询操作:用到PDOStatement PDO::query(string $statement);
如:$stmt=$pdo->query($sql);获取查询结果集
$stmt->rowCount()获取总共条数
$stmt->columnCount()获取总列数(字段)
3)pdo中的遍历操作:操作有fetch()、fetchAll()
PDO::FETCH_ASSOC 把一条记录遍历到关联数组中
PDO::FETCH_NUM 索引数组
PDO::FETCH_BOTH 混合型数组
PDO::FETCH_OBJ 把一条记录遍历到对象中
PDO::FETCH_BOUND(bindColumn)
9,mysql预处理:在sql语句结构和形式相同的情况下,只有参数不同所采用的一种数据处理机制,其极大的减少了带宽的浪费
1)目的:为了节约服务器带宽,避免资源的浪费
2)基本语法:
MySQL中的预处理方法:{
创建预处理语句
prepare 预处理指令 from sql语句(inser/delete/update/select)
设置参数
set @value =value
执行预处理
execute 预处理指令
如:prepare stmt1 from 'insert into user values(null,?,?,?)';
set@user_name='itcast';
set@user_password='123456';
set@user_image='default';
execute stmt1 using @user_name,@user_password,@user_image;
}
10,PDO预处理{
$sql="insert/update/delete into 表名 values(null,?,?,?)"
$stmt=$pdo->prepare($sql)
//预处理语句中如果使用?这个特殊字符的话,那么接下来的出入数组就必须要使用枚举数组
$data=array(
0=>'第一个问号的内容',
1=>'第一个问号的内容',
2=>'第一个问号的内容',
)
$stmt->execute($data)
}
11,PDO中的事务处理:要么同时成功,如果有一方失败,则数据回滚
应用场景:涉及金钱交易的时候使用
1)
MYSQL中的事务处理:如果想实现事务处理,则数据表的引擎必须是innoDB
.......
$con->autocommit(false)//关闭自动提交功能
$sql1=".....";
$sql2=".....";
$res1=$con->query($sql1);
$res2=$con->query($sql2);
if($res1&&$res2){
$con->commit();//提交事务
$conn->autocommit(true);//开启自动提交功能
}else{
$conn->rollback();//执行回滚
}
2)PDO中的事务处理:
开启事务
bool PDO::beginTransaction(void)
提交事务
bool PDO::commit(void)
回滚事务
bool PDO::rollback(void)
12,PDO中的异常捕获
基本语法:
try{
}catch(Exception $e){
echo '错误号:'.$e->getCode();
echo '错误行号:'.$e->getLine();
echo '错误文本信息:'.$e->getMessage();
}
该方法只能捕获致命错误,同时可以设置属性实现捕获逻辑异常
语法:
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
PDO::ATTR_ERRMODE 错误级别
1)PDO::ERRMODE_SLIENT 常规错误,默认
1)PDO::ERRMODE_WARNING 警告错误
1)PDO::ERRMODE_EXCEPTION 异常错误
13,PDO中属性的设置和获取
1)知识点:
设置属性
bool PDO::setAttribute(int $attribute,mixed $value)
获取属性
mixed PDO::getAttribute(int $attribute)
2)常用属性
PDO::ATTR_AUTOCOMMIT:自动提交
1:自动提交
0:关闭自动提交
$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0)//关闭自动提交
PDO::ATTR_CASE:结果集大小写
参数值:PDO::CASE_LOWER 结果集字段名称转化为大写
参数值:PDO::CASE_UPPER 结果集字段名称转化为大写
参数值:PDO::CASE_NATURAL 正常返回
$pdo->setAttribute(PDO::ATTR_CASE,PDO::CASE_LOWER)//设置结果集为小写
PDO::ATTR_PERSISTENT:长连接
注意长连接属性的设置,需要在连接数据库时设置
$data=array(PDO::ATTR_PERSISTENT=>true);
$pdo=new PDO($dsn,$user,$pass,$data);
pdo的简单介绍和使用的更多相关文章
- PHP5中PDO的简单使用
PHP5中PDO的简单使用 标签: php数据库mysql扩展extensionexception 2012-05-06 10:27 27753人阅读 评论(0) 收藏 举报 分类: PHP(6) ...
- 《PHP 5.5从零開始学(视频教学版)》内容简单介绍、文件夹
<PHP 5.5从零開始学(视频教学版)>当当网购买地址: http://product.dangdang.com/23586810.html <PHP 5.5从零開始学(视频教学版 ...
- [原创]关于mybatis中一级缓存和二级缓存的简单介绍
关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...
- 利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍
一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...
- 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍
一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...
- yii2的权限管理系统RBAC简单介绍
这里有几个概念 权限: 指用户是否可以执行哪些操作,如:编辑.发布.查看回帖 角色 比如:VIP用户组, 高级会员组,中级会员组,初级会员组 VIP用户组:发帖.回帖.删帖.浏览权限 高级会员组:发帖 ...
- angular1.x的简单介绍(二)
首先还是要强调一下DI,DI(Denpendency Injection)伸手获得,主要解决模块间的耦合关系.那么模块是又什么组成的呢?在我看来,模块的最小单位是类,多个类的组合就是模块.关于在根模块 ...
- Linux的简单介绍和常用命令的介绍
Linux的简单介绍和常用命令的介绍 本说明以Ubuntu系统为例 Ubuntu系统的安装自行百度,或者参考http://www.cnblogs.com/CoderJYF/p/6091068.html ...
- iOS-iOS开发简单介绍
概览 终于到了真正接触IOS应用程序的时刻了,之前我们花了很多时间去讨论C语言.ObjC等知识,对于很多朋友而言开发IOS第一天就想直接看到成果,看到可以运行的IOS程序.但是这里我想强调一下,前面的 ...
随机推荐
- jmiter性能测试
1. Jmeter简介Apache JMeter是一款纯java编写负载功能测试和性能测试开源工具软件.相比Loadrunner而言,JMeter小巧轻便且免费,逐渐成为了主流的性能测试工具,是每个测 ...
- WMS程序部署
UI部署UI-20190107-landor-修改什么BUG.JAR162\163 APP部署 外部JSP部署 备份META这个SCHEMA
- usb设备驱动的分析
怎样来分析驱动程序呢? 1.将一个usb设备插入到电脑上,在串口软件上能够显示一些打印信息,用source insight软件打开linux内核2.6.22版本,然后从第一行查找通用的关键字,找到这一 ...
- redis缓存与数据库一致性问题
一般来说,如果允许缓存可以稍微的跟数据库偶尔有不一致的情况,也就是说如果你的系统不是严格要求 “缓存+数据库” 必须保持一致性的话,最好不要做这个方案,即:读请求和写请求串行化,串到一个内存队列里去. ...
- 轻量级富文本编辑器wangEditor
开发公司一个系统的时候需要一个富文本编辑器,找了几个,最后选择这个,蛮不错的. 百度搜索wangEditor,进入官网根据所介绍的使用进行开发就可以了,很不错的一个工具.
- 2018-2019-2 20165315 《网络对抗技术》Exp3 免杀原理与实践
2018-2019-2 20165315 <网络对抗技术>Exp3 免杀原理与实践 一.实验内容 正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil-evasion ...
- ARM汇编指令格式
一.ARM介绍 1) arm汇编中,程序下一步执行哪一条指令,是根据程序计数器(PC)的值来决定. 类比于8086的CS:IP的功能. 2) 8086属于CISC(复杂指令集),每条指令长度不等,ar ...
- Spring的xml配置文件中约束的必要性 找不到元素 'beans' 的声明
今天在复习Spring MVC框架的时候,只知道xml配置文件中的约束有规范书写格式的作用,所以在配置HandlerMapping对象信息的时候没有加入约束信息之后进行测试,没有遇到问题.后来在配置S ...
- 1. String可调用方法
class str(basestring): """ str(object='') -> string Return a nice string represent ...
- IIS配置支持跨域请求
对于初次在IIS部署网站的同学,很容易忽略或不知道如何配置使其网站支持跨域请求,这里介绍一个最基础的方式,配置HTTP响应标头. 在IIS上选择HTTP响应标头,选择添加自定义响应标头,通常我们会添加 ...