PDO(PHP Data Objects)是一种在PHP里连接数据库的使用接口。PDO与mysqli曾经被建议用来取代原本PHP在用的mysql相关函数,基于数据库使用的安全性,因为后者欠缺对于SQL资料隐码的防护。

PDO是连接数据库的另一种方法,之前用到的是mysqli,PDO 不是单纯的连接musql数据库,还可以连接到sqlserve oracl等等数据库,用起来更方便一些。

PDO 一个最大的特点就是具有事务性, 主要运用在财务方面,在执行的时候是一起通过,或者一起出现异常的,比如财务在转账过程中,一处的财务增加了,那么另一处的财务肯定会有所减少,运用PDO 就可以避免出现一处财务

增加了,而另一处财务没有减少的情况。

并不能使用PDO扩展本身执行任何数据库操作,必须使用一个database-specific PDO driver(针对特定数据库的PDO驱动)访问数据库服务器。PDO并不提供数据库抽象,它并不会重写SQL或提供数据库本身缺失的功能,如果你需要这种功能,你需要使用一个更加成熟的抽象层。

 <?php
//创建对象
$dsn="mysql:dbname=test;host=localhost;"; $pdo=new PDO($dsn,"root","root"); //将PDO的错误类型设置为异常模式
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); try{
//开启事务
$pdo->beginTransaction(); $sql1="insert into score VALUES ('110','3-215','90') ";
$sql2="insert into score VALUES ('111','3-215','92')"; //这两条语句是一起执行的,如果出错,这两条语句都是无法执行的 $pdo->exec($sql1); //如果是select语句 用query()调用就可以了
$pdo->exec($sql2); //提交事务
$pdo->commit();
}
catch(Exception $e)
{ //回滚操作
$pdo->rollBack();
}
?>

未操作前的数据库 操作后的数据库(提交事务后是一起出现在数据库的)

如果是添加大批量的数据的时候,用上面的方法写起来可能会比较麻烦一些, 下面是比较简单的方法,运用数组的模式来写

 //创建对象
$dsn="mysql:dbname=test;host=localhost";
$pdo=new PDO($dsn,"root","root");
//预处理SQL语句
$sql="insert into score VALUES (:sno,:cno,:degree)";
$stem=$pdo->prepare($sql); //造一个数组
$arr=array("sno"=>"120","cno"=>"95033","degree"=>88); //执行
$stem->execute($arr);

下面是举例说明这种方法的简单之处:写一个添加页面和其处理页面

 //这是添加页面
<body>
<h1>添加页面</h1>
<form action="pdoadd.php" method="post">
<div>学号:<input type="text" name="sno"/></div>
<div>班级:<input type="text" name="cno"/></div>
<div>成绩:<input type="text" name="degree"/></div>
<div><input type="submit" value="添加"/></div>
</form>
</body>

显示如图

 //这是添加处理页面
<?php
$dsn="mysql:dbname=test;host=localhost";
$pdo=new PDO($dsn,"root","root");
//预处理语句
$sql="insert into score VALUES (:sno,:cno,:degree)";
$tem=$pdo->prepare($sql);
//执行
$tem->execute($_POST);
?>

从添加的处理页面可以看出,用pdo来处理相对于mysqli来处理要简单一些的

PDO控制、连接数据库的更多相关文章

  1. PDO方法连接数据库(怕忘记,记起来)

    PDO方法连接数据库更加安全! [完整代码,只需要添上对应的数据库即可以运行] <?php include "init.inc.php"; //--------------- ...

  2. PHP pdo单例模式连接数据库

    PHP pdo单例模式连接数据库<pre><?php class Db{ private static $pdo; public static function getPdo () ...

  3. 封装PDO连接数据库代码

    废话不说直接上代码: <?php class DB { protected static $_connect; protected $dsn, $pdo; protected $_data, $ ...

  4. php PDO连接mysql

    近期在linux装了新的环境.php5.6+mysql5.5+nginx. 然后用原来的mysql链接数据库出现的错误. 原因就是说连接数据库的方法太旧.建议我用mysqli和PDO来连接数据库. 好 ...

  5. 数据库PDO简介

    php简介,php历史,php后端工程师职业前景,php技术方向,php后端工程师职业体系介绍. php是世界上使用最广泛的web开发语言,是超文本预处理器,是一种通用的开源脚本语言,语法吸收了c语言 ...

  6. [kohana] kohana3.2,如何兼容PDO数据库连接方式

    由于历史原因,有个kohana3.2的站点需要搬迁到php5.5上来,但php5.5已经不支持mysql_connect()这个函数了,只能使用PDO来连接数据库. 但换上PDO之后,报了这个的一个错 ...

  7. 我懒蛋又回来了!-PDO

    hi 好几天了吧,脚伤都有一周了的.玩乐的这么久才发觉,对于年轻人,或者更具体的,对我而言,受伤最难受的不是受伤瞬间的身痛,不是随之而来的心理负担,不是独自一人远在他乡的孤独无助之感:最伤的是斗志,是 ...

  8. PHP中用PDO方法打开连接关闭mysql数据库

    代码如下: <meta http-equiv="content-type" content="text/html" charset="utf-8 ...

  9. PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码

    PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty) dbconn.php <?php //------------------------使用PDO方式连接数据库文件- ...

随机推荐

  1. 360路由器+花生壳实现外网访问SVN服务器

    注册花生壳账号 花生壳注册地址:https://console.oray.com/passport/register.html?fromurl=http%3A%2F%2Fhsk.oray.com%2F ...

  2. Bmob 之 列表查询

    查询列表,返回前20个数据: //创建BmobQuery实例,指定对应要操作的数据表名称 BmobQuery *query = [BmobQuery queryWithClassName:classN ...

  3. js原生设计模式——2面向对象编程之闭包1

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  4. 谱聚类 Spectral Clustering

    转自:http://www.cnblogs.com/wentingtu/archive/2011/12/22/2297426.html 如果说 K-means 和 GMM 这些聚类的方法是古代流行的算 ...

  5. js动态设置输入框字体/颜色

    动态设置文本框颜色: 主要是利用javascript中的触发事件onfocus和onblur <script language="javascript" type=" ...

  6. Java之模板方法模式(Template Method)

    Java之模板方法模式(Template Method) 1. 概念:定义一个算法的骨架,而将一些实现步骤延迟到子类中. 把不变的行为搬到超类,去除子类中重复的代码来体现他的优势. 2. UML图: ...

  7. FlashPlayer11 异步解码 Bitmap

    Flash Player 11引入了一个全新的功能是异步解码位图的功能,这个功能对某些类型的Flash应用会很有效,尤其是需要加载大分辨率的位图的相册或游戏会有显著效果,使用位图图像时,可以异步解码和 ...

  8. Bootstrap入门(十七)组件11:分页与标签

    Bootstrap入门(十七)组件11:分页与标签   1.默认样式的分页 2.分页的大小 3.禁用的分页 4.翻页的效果 5.两端对齐的分页 6. 标签的不同样式 7. 标签的大小   先引入本地的 ...

  9. 冒泡排序 - vb.net

    Imports System.ThreadingModule Module1    Sub Main()        Dim int_array(9) As Integer        Dim r ...

  10. Nancy简单实战之NancyMusicStore(六):写在最后

    前言 由于公司搬家后,住的地方离上班的地方远了N倍,以前是走路十多分钟就可以到公司的,上班时间也从9:00提早到8:30 现在每天上班都是先坐公交,然后再坐地铁,在这段路上比较浪费时间而且每天都是要6 ...