首页 后端开发 php教程 php pdo函数库用法详解

php pdo函数库用法详解

Jul 25, 2016 am 08:54 AM

  1. pdo->begintransaction() — 标明回滚起始点
  2. pdo->commit() — 标明回滚结束点,并执行sql
  3. pdo->__construct() — 建立一个pdo链接数据库的实例
  4. pdo->errorcode() — 获取错误码
  5. pdo->errorinfo() — 获取错误的信息
  6. pdo->exec() — 处理一条sql语句,并返回所影响的条目数
  7. pdo->getattribute() — 获取一个“数据库连接对象”的属性
  8. pdo->getavailabledrivers() — 获取有效的pdo驱动器名称
  9. pdo->lastinsertid() — 获取写入的最后一条数据的主键值
  10. pdo->prepare() — 生成一个“查询对象”
  11. pdo->query() — 处理一条sql语句,并返回一个“pdostatement”
  12. pdo->quote() — 为某个sql中的字符串添加引号
  13. pdo->rollback() — 执行回滚
  14. pdo->setattribute() — 为一个“数据库连接对象”设定属性
复制代码

二、pdostatement

  1. pdostatement->bindcolumn() — bind a column to a php variable
  2. pdostatement->bindparam() — binds a parameter to the specified variable name
  3. pdostatement->bindvalue() — binds a value to a parameter
  4. pdostatement->closecursor() — closes the cursor, enabling the statement to be executed again.
  5. pdostatement->columncount() — returns the number of columns in the result set
  6. pdostatement->errorcode() — fetch the sqlstate associated with the last operation on the statement handle
  7. pdostatement->errorinfo() — fetch extended error information associated with the last operation on the statement handle
  8. pdostatement->execute() — executes a prepared statement
  9. pdostatement->fetch() — fetches the next row from a result set
  10. pdostatement->fetchall() — returns an array containing all of the result set rows
  11. pdostatement->fetchcolumn() — returns a single column from the next row of a result set
  12. pdostatement->fetchobject() — fetches the next row and returns it as an object.
  13. pdostatement->getattribute() — retrieve a statement attribute
  14. pdostatement->getcolumnmeta() — returns metadata for a column in a result set
  15. pdostatement->nextrowset() — advances to the next rowset in a multi-rowset statement handle
  16. pdostatement->rowcount() — returns the number of rows affected by the last sql statement
  17. pdostatement->setattribute() — set a statement attribute
  18. pdostatement->setfetchmode() — set the default fetch mode for this statement
复制代码

详解1) pdo中的数据库连接

  1. $dsn = ‘mysql:dbname=ent;host=127.0.0.1′;
  2. $user = ‘root';
  3. $password = ‘123456′;
  4. try {
  5. $dbh = new pdo($dsn, $user, $password, array(pdo::attr_persistent => true));
  6. $dbh->query('set names utf8;');
  7. foreach ($dbh->query('select * from tpm_juese') as $row) {
  8. print_r($row);
  9. }
  10. } catch (pdoexception $e) {
  11. echo ‘connection failed: ‘ . $e->getmessage();
  12. }
复制代码

许多web应用会因为使用了向数据库的持久连接而得到优化。持久连接不会在脚本结束时关闭, 相反它会被缓存起来并在另一个脚本通过同样的标识请求一个连接时得以重新利用。 持久连接的缓存可以使你避免在脚本每次需要与数据库对话时都要部署一个新的连接的资源消耗,让你的web应用更加快速。 上面实例中的array(pdo::attr_persistent => true)就是把连接类型设置为持久连接。

详解2) pdo中的事务 pdo->begintransaction(),pdo->commit(),pdo->rollback()这三个方法是在支持回滚功能时一起使用的。 pdo->begintransaction()方法标明起始点,pdo->commit()方法标明回滚结束点,并执行sql,pdo->rollback()执行回滚。

  1. try {
  2. $dbh = new pdo('mysql:host=localhost;dbname=test', ‘root', ”);
  3. $dbh->query('set names utf8;');
  4. $dbh->setattribute(pdo::attr_errmode, pdo::errmode_exception);
  5. $dbh->begintransaction();
  6. $dbh->exec(”insert into `test`.`table` (`name` ,`age`)values ('mick', 22);”);
  7. $dbh->exec(”insert into `test`.`table` (`name` ,`age`)values ('lily', 29);”);
  8. $dbh->exec(”insert into `test`.`table` (`name` ,`age`)values ('susan', 21);”);
  9. $dbh->commit();
  10. } catch (exception $e) {
  11. $dbh->rollback();
  12. echo “failed: ” . $e->getmessage();
  13. }
  14. ?>
复制代码

现在已经通过pdo建立了连接,在部署查询之前你必须搞明白pdo是怎样管理事务的。如果你以前从未遇到过事务处理,(现在简单介绍一下:)它们提供了4个主要的特性:原子性,一致性,独立性和持久性(atomicity, consistency, isolation and durability,acid)通俗一点讲,一个事务中所有的工作在提交时,即使它是分阶段执行的,也要保证安全地应用于数据库,不被其他的连接干扰。事务工作也可以在请求发生错误时轻松地自动取消。

事务的典型运用就是通过把批量的改变“保存起来”然后立即执行。这样就会有彻底地提高更新效率的好处。换句话说,事务可以使你的脚本更快速同时可能更健壮(要实现这个优点你仍然需要正确的使用它们)。

不幸运的是,并不是每个数据库都支持事务,因此pdo需要在建立连接时运行在被认为是“自动提交”的模式下。自动提交模式意味着你执行的每个查询都有它自己隐含的事务处理,无论数据库支持事务还是因数据库不支持而不存在事务。如果你需要一个事务,你必须使用 pdo->begintransaction() 方法创建一个。如果底层驱动不支持事务处理,一个pdoexception就会被抛出(与你的异常处理设置无关,因为这总是一个严重的错误状态)。在一个事物中,你可以使用 pdo->commit() 或 pdo->rollback() 结束它,这取决于事务中代码运行是否成功。 当脚本结束时或一个连接要关闭时,如果你还有一个未处理完的事务,pdo将会自动将其回滚。这是对于脚本意外终止的情况来说是一个安全的方案——如果你没有明确地提交事务,它将会假设发生了一些错误,为了你数据的安全,所以就执行回滚了。

二、pdostatement

  1. // 修改默认的错误显示级别
  2. $dbh->setattribute(pdo::attr_errmode, pdo::errmode_warning);
  3. ?>
复制代码

属性列表: pdo::param_bool 表示一个布尔类型 pdo::param_null 表示一个sql中的null类型 pdo::param_int 表示一个sql中的integer类型 pdo::param_str 表示一个sql中的sql char,varchar类型 pdo::param_lob 表示一个sql中的large object类型 pdo::param_stmt 表示一个sql中的recordset类型,还没有被支持 pdo::param_input_output specifies that the parameter is an inout parameter for a stored procedure. you must bitwise-or this value with an explicit pdo::param_* data type. pdo::fetch_lazy 将每一行结果作为一个对象返回 pdo::fetch_assoc 仅仅返回以键值作为下标的查询的结果集,名称相同的数据只返回一个 pdo::fetch_named 仅仅返回以键值作为下标的查询的结果集,名称相同的数据以数组形式返回 pdo::fetch_num 仅仅返回以数字作为下标的查询的结果集 pdo::fetch_both 同时返回以键值和数字作为下标的查询的结果集 pdo::fetch_obj 以对象的形式返回结果集 pdo::fetch_bound 将pdostatement::bindparam()和pdostatement::bindcolumn()所绑定的值作为变量名赋值后返回 pdo::fetch_column 表示仅仅返回结果集中的某一列 pdo::fetch_class 表示以类的形式返回结果集 pdo::fetch_into 表示将数据合并入一个存在的类中进行返回 pdo::fetch_func pdo::fetch_group pdo::fetch_unique pdo::fetch_key_pair 以首个键值下表,后面数字下表的形式返回结果集 pdo::fetch_classtype pdo::fetch_serialize 表示将数据合并入一个存在的类中并序列化返回 pdo::fetch_props_late available since php 5.2.0 pdo::attr_autocommit 在设置成true的时候,pdo会自动尝试停止接受委托,开始执行 pdo::attr_prefetch 设置应用程序提前获取的数据大小,并非所有的数据库哦度支持 pdo::attr_timeout 设置连接数据库超时的值 pdo::attr_errmode 设置error处理的模式 pdo::attr_server_version 只读属性,表示pdo连接的服务器端数据库版本 pdo::attr_client_version 只读属性,表示pdo连接的客户端pdo驱动版本 pdo::attr_server_info 只读属性,表示pdo连接的服务器的meta信息 pdo::attr_connection_status pdo::attr_case 通过pdo::case_*中的内容对列的形式进行操作 pdo::attr_cursor_name 获取或者设定指针的名称 pdo::attr_cursor 设置指针的类型,pdo现在支持pdo::cursor_fwdonly和pdo::cursor_fwdonly pdo::attr_driver_name 返回使用的pdo驱动的名称 pdo::attr_oracle_nulls 将返回的空字符串转换为sql的null pdo::attr_persistent 获取一个存在的连接 pdo::attr_statement_class pdo::attr_fetch_catalog_names 在返回的结果集中,使用自定义目录名称来代替字段名。 pdo::attr_fetch_table_names 在返回的结果集中,使用自定义表格名称来代替字段名。 pdo::attr_stringify_fetches pdo::attr_max_column_len pdo::attr_default_fetch_mode available since php 5.2.0 pdo::attr_emulate_prepares available since php 5.1.3. pdo::errmode_silent 发生错误时不汇报任何的错误信息,是默认值 pdo::errmode_warning 发生错误时发出一条php的e_warning的信息 pdo::errmode_exception 发生错误时抛出一个pdoexception pdo::case_natural 回复列的默认显示格式 pdo::case_lower 强制列的名字小写 pdo::case_upper 强制列的名字大写 pdo::null_natural pdo::null_empty_string pdo::null_to_string pdo::fetch_ori_next 获取结果集中的下一行数据,仅在有指针功能时有效 pdo::fetch_ori_prior 获取结果集中的上一行数据,仅在有指针功能时有效 pdo::fetch_ori_first 获取结果集中的第一行数据,仅在有指针功能时有效 pdo::fetch_ori_last 获取结果集中的最后一行数据,仅在有指针功能时有效 pdo::fetch_ori_abs 获取结果集中的某一行数据,仅在有指针功能时有效 pdo::fetch_ori_rel 获取结果集中当前行后某行的数据,仅在有指针功能时有效 pdo::cursor_fwdonly 建立一个只能向后的指针操作对象 pdo::cursor_scroll 建立一个指针操作对象,传递pdo::fetch_ori_*中的内容来控制结果集 pdo::err_none (string)

设定没有错误时候的错误信息 pdo::param_evt_alloc allocation event pdo::param_evt_free deallocation event pdo::param_evt_exec_pre event triggered prior to execution of a prepared statement. pdo::param_evt_exec_post event triggered subsequent to execution of a prepared statement. pdo::param_evt_fetch_pre event triggered prior to fetching a result from a resultset. pdo::param_evt_fetch_post event triggered subsequent to fetching a result from a resultset. pdo::param_evt_normalize event triggered during bound parameter registration allowing the driver to normalize the parameter name.



本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系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无尽的。

热工具

记事本++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 API中说明JSON Web令牌(JWT)及其用例。 在PHP API中说明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

描述扎实的原则及其如何应用于PHP的开发。 描述扎实的原则及其如何应用于PHP的开发。 Apr 03, 2025 am 12:04 AM

SOLID原则在PHP开发中的应用包括:1.单一职责原则(SRP):每个类只负责一个功能。2.开闭原则(OCP):通过扩展而非修改实现变化。3.里氏替换原则(LSP):子类可替换基类而不影响程序正确性。4.接口隔离原则(ISP):使用细粒度接口避免依赖不使用的方法。5.依赖倒置原则(DIP):高低层次模块都依赖于抽象,通过依赖注入实现。

如何在系统重启后自动设置unixsocket的权限? 如何在系统重启后自动设置unixsocket的权限? Mar 31, 2025 pm 11:54 PM

如何在系统重启后自动设置unixsocket的权限每次系统重启后,我们都需要执行以下命令来修改unixsocket的权限:sudo...

解释PHP中晚期静态结合的概念。 解释PHP中晚期静态结合的概念。 Mar 21, 2025 pm 01:33 PM

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

如何用PHP的cURL库发送包含JSON数据的POST请求? 如何用PHP的cURL库发送包含JSON数据的POST请求? Apr 01, 2025 pm 03:12 PM

使用PHP的cURL库发送JSON数据在PHP开发中,经常需要与外部API进行交互,其中一种常见的方式是使用cURL库发送POST�...

框架安全功能:防止漏洞。 框架安全功能:防止漏洞。 Mar 28, 2025 pm 05:11 PM

文章讨论了框架中的基本安全功能,以防止漏洞,包括输入验证,身份验证和常规更新。

在PHPStorm中如何进行CLI模式的调试? 在PHPStorm中如何进行CLI模式的调试? Apr 01, 2025 pm 02:57 PM

在PHPStorm中如何进行CLI模式的调试?在使用PHPStorm进行开发时,有时我们需要在命令行界面(CLI)模式下调试PHP�...

See all articles