2014-09-05
在我的PHP开发过程中,数据库的采用都是使用mysql数据库,与数据库有关的操作基本上都是使用php中的mysql扩展函数,例如mysql_query,mysql_connect等函数,使用这些传统的方法来连接查询数据库时,个人觉得有两个弊端,一是没有扩展性,就是只能用在mysql数据库中,如果要更换数据库的之后,使用的PHP扩展函数不同,如果在开发过程中要更换数据库,那么所有与数据库有关的操作都要重来了;第二个是如果过滤语句不严密,就会有SQL注入的风险,导致网站被恶意攻击,失去控制。虽然用mysql_real_escape_string()函数过滤用户提交的值,但是也有缺陷。而使用PHP的PDO扩展的 prepare 方法,就可以有效地避免sql injection 风险。
1、PDO介绍
PDO扩展为PHP访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询和获取数据。PDO随PHP5.1发行,在PHP5.0的PECL扩展中也可以使用,无法运行于之前的PHP版本。与mysql和mysqli相比起来,PDO让跨数据库的使用更具有亲和力。
2、PDO的安装与配置
在php5.2.10中,php默认已经安装了pdo。
打开php.ini文件,找到extension=php_pdo.dll这一句,去掉前面的注释符号,然后重启apache即可。如果没有找到这句,可以自己添加一句或者查看系统在安装的时候是否采用了动态链接库文件.so,如果是的话,可以在php目录下找到一个conf.d的文件夹,下面有一个pdo.ini的链接文件,如果里面有一句extension=pdo.so说明已经开启了PDO。
验证一下PHP是否已经开启了PDO,首先写一个脚本,内容是
3、创建一个PDO对象
__construct(string dsn[,string username [,string password [, array driver_options]]]);//pdo的构造方法参数解析:第一个必选参数是数据源名DSN,用来定义一个确定的数据库和必须用到的驱动程序。
如,连接oracle服务器和mysql服务器的DSN格式分别如下所示:
ocl:dbname=//127.0.0.1:1521/mydb //连接oracle服务器的dsn,oci:作为驱动前缀,主机127.0.0.1,端口1521,数据库mydb
mysql:host=127.0.0.1;dbname=testdb //连接Mysql服务器的dsn,mysql:作为驱动前缀,主机127.0.0.1,数据库testdb
$dsn = 'mysql:dbname=testdb;host=127.0.0.1'; $user = 'root'; $password = 'root'; try { $dbh = new PDO($dsn, $user, $password); }catch(PDOException $e) { echo "connect failed: ".$e->getMessage(); }
$dbh->setAttribute(PDO::ATTR_ERrmODE, PDO::ERrmODE_EXCEPTION);当设置为PDO::ERrmODE_SILENT时可以通过调用errorCode() 或errorInfo()来获得错误信息,当然其他情况下也可以。 2) 因为不同数据库对返回的字段名称大小写处理不同,所以PDO提供了PDO::ATTR_CASE设置项(包括PDO::CASE_LOWER,PDO::CASE_NATURAL,PDO::CASE_UPPER),来确定返回的字段名称的大小写。
3) 通过设置PDO::ATTR_ORACLE_NULLS类型(包括PDO::NULL_NATURAL,PDO::NULL_EmpTY_STRING,PDO::NULL_TO_STRING)来指定数据库返回的NULL值在php中对应的数值。
5、PDO常用方法及其应用
PDO::query() 主要是用于有记录结果返回的操作,特别是SELECT操作
PDO::exec() 主要是针对没有结果集合返回的操作,如INSERT、UPDATE等操作
PDO::prepare() 主要是预处理操作,需要通过$rs->execute()来执行预处理里面的SQL语句,这个方法可以绑定参数,功能比较强大(防止sql注入就靠这个)
PDO::lastInsertId() 返回上次插入操作,主键列类型是自增的最后的自增ID
PDOStatement::fetch() 是用来获取一条记录
PDOStatement::fetchAll() 是获取所有记录集到一个集合
PDOStatement::fetchColumn() 是获取结果指定第一条记录的某个字段,缺省是第一个字段
PDOStatement::rowCount() :主要是用于PDO::query()和PDO::prepare()进行DELETE、INSERT、UPDATE操作影响的结果集,对PDO::exec()方法和SELECT操作无效。
6、PDO操作MYSQL数据库实例
$sql = "UPDATE article SET title="haha" WHERE id=1";$affected = $dbh->exec($query);if($affected) { echo "successed";}else { print_r($dbh->errorINdo());}
$SQLStatament = "INSERT INTO article VALUES(":title, :content")";$param = array(":title" => "something", ":content" => "aaaa");//准备的参数,对应数据库的字段$stmt = $dbh->prepare($SQLStatement);$stmt->execute($param);
1
CI框架连接数据库配置操作以及多数据库操作
09-05
2
asp 简单读取数据表并列出来 ASP如何快速从数据库读取大量数据
05-17
3
C语言关键字及其解释介绍 C语言32个关键字详解
04-05
4
C语言中sizeof是什么意思 c语言里sizeof怎样用法详解
04-26
5
最简单的asp登陆界面代码 asp登陆界面源代码详细介绍
04-12
6
PHP中的魔术方法 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep,
09-05
7
PHP中的(++i)前缀自增 和 (i++)后缀自增
09-05
8
PHP中include和require区别之我见
09-05
常用dos命令及语法
2014-09-27
将视频设置为Android手机开机动画的教程
2014-12-11
php递归返回值的问题
2014-09-05
如何安装PHPstorm并配置方法教程 phpstorm安装后要进行哪些配置
2017-05-03
java中的info是什么意思
2022-03-24
PHP 教程之如何使用BLOB存取图片信息实例
2014-09-05
IcePHP框架中的快速后台中的通用CRUD功能框架
2014-09-05
单片机编程好学吗?单片机初学者怎样看懂代码
2022-03-21
PHP数组函数array
2014-09-05
学ug编程如何快速入门?
2022-03-17
拳皇14官方正版下载v2.0.0 安卓正式版
动作闯关 1.06G
下载勇者大战魔物娘安卓手游下载v1.10.29 安卓冷狐汉化版
角色扮演 792.3M
下载贝比岛最新版下载v2.5.4 安卓官方版
其它手游 32.9M
下载奥特曼格斗进化3高清汉化版(Ultraman Fighting Evolution 3)下载v3.3.2 安卓免费版
动作闯关 2.19G
下载王者荣耀全英雄全皮肤版本下载v10.11.7.1 安卓版
其它手游 454.5M
下载漫威超级战争手游下载v3.23.0 安卓手机版
动作闯关 1.90G
下载悟饭游戏厅苹果版(我Fun趣味)下载v1.5.6 iPhone版
其它手游 125.7M
下载无畏契约valorant官方版下载v1.0.3 安卓版
射击枪战 150.3M
下载飞羽青春羽毛球游戏下载v1.9.2 安卓官方版
下载
斗罗大陆诛邪传说手游下载v2.0.18 安卓版
下载
kisakibluearchive(碧蓝档案)下载v1.0 安卓手机版碧蓝档案妃咲同人小游戏
下载
恐怖奶奶联机版游戏下载v1.4.1.5 安卓手机版
下载
失落之城中文版下载v8.8 官方安卓版
下载
舰载机着舰模拟器最新版本(Carrier Landing HD)下载v2020.6.02 安卓版
下载
边境之旅最新版本下载v4.2.0 安卓完整版
下载
植物大战僵尸PVZ指导版2.0下载v1.0 安卓版
下载