首页 后端开发 PHP问题 php中pdo怎么使用

php中pdo怎么使用

Apr 21, 2023 pm 02:24 PM
php pdo用法

php中pdo是一个扩展类库,可以为php定义一个轻级、一致性的接口,其使用方法如:1、创建一个php示例文件;2、通过“try{$link = new PDO(.);}catch(PDOException $e){...}”方式创建pdo对象;3、通过“$link->query('select *from user');”方式执行查询,返回结果集对象即可。

php中pdo怎么使用

本操作系统环境:Linux5.18.14系统、Dell G3电脑。

一、 基本概念

1、 PDO:PHP Data Object的缩写。PDO扩展类库为PHP定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样无论使用什么数据库,都可以通过一致的函数执行查询和获取数据。

PDO就是一个“数据库访问抽象层”,作用是统一各种数据库的访问接口。

2、 对任何数据库的操作,并不是使用PDO扩展本身执行的,必须针对不同的数据库服务器使用特定的PDO驱动程序访问。如:MYSQL(PDO_MYSQL)。可以在phpinfo()函数中查看PDO部分的列表。

二、PDO的安装

1、Linux:安装PHP时,向configure命令中添加如下标志:

–with-pdo-mysql=/usr/local/mysql //其中/usr/local/mysql为mysql安装目录

2、Windows:

在C:windows下找到php.ini文件

(1)打开:extension=php_pdo.dll

(2)打开:extension=php_pdo_mysql.dll

三、使用PDO过程

1、连接数据库

2、创建PDO对象:

(1)$link = new PDO(DSN, 用户名, 密码, 驱动属性);

1)DSN:数据源名,用来定义一个必须用到的驱动程序和要使用的数据库。mysql的DSN格式:’mysql:host=localhost;dbname=lamp30’

2)可以将DSN放到文件里,如:’uri:file:///usr/local/dsn.txt’

3)创建对象时要使用try…catch语句,因为在声明PDO实例发生错误时,会自动抛出一个异常。如:

代码如下

try{
$link = new PDO(‘mysql:host=localhost;dbname=lamp30’,’root’,’111111’);
}catch(PDOException $e){
echo $e->getMessage();
exit(‘连接数据库错误.’);
}
登录后复制

3、驱动属性

(1)可以将必要的几个选项组成数组(属性名作为元素键,属性值作为元素值)传递给构造方法的第四个参数。如果没有在构造方法中定义驱动属性,可以在之后使用PDO类的setattribute()函数定义各个属性。

(2)书P501页有这些属性中文释义。

3、设置字符集:$link->query(‘set names UTF8’)

五、发送SQL语句

(1)$link->exec():执行增删改,返回受影响行数,执行失败返回false或0。

(2)$link->query():执行查询,返回PDOStatement结果集对象。

六、查询结果

1、非查询:

(1)直接用$link->exec()的返回影响行数

(2)$link->lastInsertId()返回最后一条INSERT命令生成的AUTO_INCREMENT编号值

2、见预处理

七、预处理

1、第二步:发送SQL语句

代码如下

$stmt = $link->prepare(‘select * from user where id=:id’);
$stmt->bindparam(‘:id’, $id, PDO::PARAM_INT);
$id = 2;
$stmt->execute();
登录后复制

bindParam()参数有以下7种:可以不用写

PDO::PARAM_INT

PDO::PARAM_STR

PDO::PARAM_BOOL

PDO::PARAM_NULL

PDO::PARAM_LOB:大对象数据类型

PDO::PARAM_STMT:PDOstatement类型

PDO::PARAM_INPUT_OUTPUT:存储过程使用的数据类型

2、第三步:

如:

代码如下

$stmt = $link->query(‘select * from user’);
登录后复制

(1)fetch()方法

$pdoStat ->bindColumn(1, $id); //第一个参数可以是从1开始的索引值
$pdoStat ->bindColumn(‘name’, $name); //也可以是列名
$pdoStat ->bindColumn(‘pass’, $pass);
while($row = $stmt ->fetch(PDO::FETCH_BOUND)){
echo $id.’ ’;
echo $name.’ ’;
echo $pass.’
’;
}
登录后复制

fetch()参数有六种:见手册。

可以用setFetchMode()方法设置默认模式。

(2)fetchall()方法

代码如下

$result = $stmt ->fetchall();
foreach($result as $row){
echo $row[‘id’].’ ’;
echo $row[‘name’].’ ’;
echo $row[‘pass’].’
’;
}
登录后复制

Fetchall()参数与fetch()相同。

八、事务处理

1、关闭自动提交(在驱动属性中修改)

2、打开事务

3、提交事务/回滚

4、打开自动提交

如:

代码如下

$link = new PDO(‘mysql:host=localhost;dbname=lamp30’);
//1
$link->setattribute(PDO::ATTR_AUTOCOMMIT, false);
//2
$link->begintransaction();
$result = $link->exec(‘insert into user(name,paa) values(‘wsy’,’111’)’);
//3
if($result){
$link->commit();
}else{
$link->rollback();
}
//4
$link->setattribute(PDO::ATTR_AUTOCOMMIT, true);
登录后复制

九、PDO对象中的成员方法

1、$link->getattribute(属性名):获取一个驱动属性。

2、$link->setattribute(属性名,属性值):设置一个驱动属性。

1)因oracle把空字符串返回为NULL值,而其它数据库无此特性,为了有更好的兼容性$link->setattribute(PDO::ATTR_ORACLE_NULLS ,PDO::NULL_EMPTY_STRING,);

2)有三种显示错误的方式:静态、WARNING消息、异常

3、$link->errorcode():获取错误码。

1)如setattribute函数设置显示错误方式为静态,则出现错误时什么都不显示,必须调用此函数,才能查看错误号。

4、$link->errorinfo():获取错误信息(数组)。

1)如setattribute函数设置显示错误方式为静态,则出现错误时什么都不显示,必须调用此函数,才能查看错信息。

5、$link->lastinsertid():获取插入到表中的最后一条数据主键值(如有多条数据同时插入,返回第一个插入行的ID)。

6、$link->prepare():发送准备的SQL语句,返回PDOStatement对象。

7、$link->begintransaction():打开事务。

8、$link->commit():提交一个事务,执行一个SQL。

9、$link->rollback():回滚一个事务。

十、错误模式

1、静态模式:

代码如下

$link->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT)
登录后复制

(1) 默认模式,在错误发生时不进行任何操作,PDO将只设置错误代码。

(2) 查看错误可以调用errorCode()和errorInfo(),PDO和PDOStatement类都有这两个方法。

2、警告模式:

代码如下

$link->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING)
登录后复制

(1)此模式在设置错误代码以外,PDO还将发出一条PHP传统的E_WARNING消息。

(2)这是mysql和mysqli显示错的方式。

3、异常模式:

代码如下

$link->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION)
登录后复制

(1) 此模式在设置错误代码以外,PDO还将抛出一个PDOException,并设置其属性,以反映错误代码和错误信息。

(2) 如果异常导致脚本终止,则事务将自动回滚。

(3) PDO推荐使用此模式。

十一、持久连接

代码如下

$link->setAttribute(PDO::ATTR_PERSISTENT, true);
登录后复制

持久连接即当脚本执行结束时不会自动断开连接,而且用$link->close()不能关闭连接。

以上是php中pdo怎么使用的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP 8 JIT(即时)汇编:它如何提高性能。 PHP 8 JIT(即时)汇编:它如何提高性能。 Mar 25, 2025 am 10:37 AM

PHP 8的JIT编译通过将代码经常汇编为机器代码,从而增强了性能,从而使应用程序有益于大量计算并减少执行时间。

PHP安全文件上传:防止与文件相关的漏洞。 PHP安全文件上传:防止与文件相关的漏洞。 Mar 26, 2025 pm 04:18 PM

本文讨论了确保PHP文件上传的确保,以防止诸如代码注入之类的漏洞。它专注于文件类型验证,安全存储和错误处理以增强应用程序安全性。

PHP加密:对称与非对称加密。 PHP加密:对称与非对称加密。 Mar 25, 2025 pm 03:12 PM

本文讨论了PHP中的对称和不对称加密,并比较了它们的适用性,性能和安全差异。对称加密速度更快,适合大量数据,而不对称的键交换则使用。

OWASP前10 php:描述并减轻常见漏洞。 OWASP前10 php:描述并减轻常见漏洞。 Mar 26, 2025 pm 04:13 PM

本文讨论了OWASP在PHP和缓解策略中的十大漏洞。关键问题包括注射,验证损坏和XSS,并提供用于监视和保护PHP应用程序的推荐工具。

PHP身份验证&授权:安全实施。 PHP身份验证&授权:安全实施。 Mar 25, 2025 pm 03:06 PM

本文讨论了在PHP中实施强大的身份验证和授权,以防止未经授权的访问,详细说明最佳实践并推荐安全增强工具。

如何使用PHP从数据库中检索数据? 如何使用PHP从数据库中检索数据? Mar 20, 2025 pm 04:57 PM

文章讨论了使用PHP从数据库中检索数据,涵盖步骤,安全措施,优化技术和解决方案的常见错误。

PHP API率限制:实施策略。 PHP API率限制:实施策略。 Mar 26, 2025 pm 04:16 PM

本文讨论了在PHP中实施API速率限制的策略,包括诸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之类的库。它还涵盖监视,动态调整速率限制和手

PHP CSRF保护:如何防止CSRF攻击。 PHP CSRF保护:如何防止CSRF攻击。 Mar 25, 2025 pm 03:05 PM

本文讨论了防止PHP中CSRF攻击的策略,包括使用CSRF代币,同一站点cookie和适当的会话管理。

See all articles