0

0

以多种方式调用构造方法创建PDO对象

黄舟

黄舟

发布时间:2017-05-20 17:19:01

|

1802人浏览过

|

来源于php中文网

原创

以多种方式调用构造方法创建pdo对象

可以以多种昂方式调构造方法创建PDO对象,下面以连接MySQL 和 Oracle 服务器为例,分别介绍构造方法的多种调用方式。

一、将参数嵌入到构造函数

在下面的连接Oracle 服务器的示例中,在DSN字符串中加载OCI驱动程序并指定里两个可选参数:第一个是数据库名称,第二个是字符集。使用了特定的字符集连接一个特定的数据库,如果不指定任何信息就会使用默认的数据库。代码如下:

getMessage();
}
?>

OCI:dbname = accounts告诉PDO它应该使用 OCI驱动程序,并且应该使用“accounts”数据库。对于MySQL驱动程序,第一个冒号后面的所有内容都将会被用作MySQL的DSN。连接MySQL 服务器的显示如下:

getMessage();
}
?>

其他的驱动程序会同样以不同的方式解析它的DSN,如果无法加载驱动程序,或者发生了连接失败,则会抛出一个PDOException,以便您可以决定如何最好的处理该故障。省略try...catch 控制结构并无裨益,如果在应用程序的较高级别没有定义异常处理,那么在无法建立数据库连接的情况下,该脚本会终止。

二、将参数存放在文件中

在创建PDO对象时,可以把DSN字符串放在另一个本地或者远程文件中,并在构造函数中引用这个文件,如下所示:

getMessage();
}
?>

只要将文件/usr/localhost/dbconnect中的DSN驱动改变,就可以在多种数据库系统之间切换,但是确保该文件由负责执行PHP脚本的用户所拥有,而且此用户拥有必要的权限。

Shell脚本编写基础 中文WORD版
Shell脚本编写基础 中文WORD版

Shell本身是一个用C语言编写的程序,它是用户使用Linux的桥梁。Shell既是一种命令语言,又是一种程序设计语言。作为命令语言,它交互式地解释和执行用户输入的命令;作为程序设计语言,它定义了各种变量和参数,并提供了许多在高级语言中才具有的控制结构,包括循环和分支。它虽然不是Linux系统核心的一部分,但它调用了系统核心的大部分功能来执行程序、建立文件并以并行的方式协调各个程序的运行。因此,对于用户来说,shell是最重要的实用程序,深入了解和熟练掌握shell的特性极其使用方法,是用好Linux系统

下载

三、引用 php.ini文件

也可以在PHP服务器的配置文件中维护DSN信息,只要在php.ini文件中吧DSN信息付给一个名为 pdo.dsn.aliasname  的配置参数,这里 aliasname  是后面将提供给构造函数的DSN别名。如下所示连接Oracle 服务器,在php.ini中为DSN指定的别名为 oraclepdo:

【PDO】
pdo.dsn.oraclepdo = “OCI:dbname=//localhost:1521/mydb;chaset=UTF-8”;

重新启动 Apaceh服务器后,就可以在php程序中,调用PDO构造方法时,在第一个参数中使用这个别名,如下所示:

getMessage();
}
?>

四、PDO与连接有关的选项

在创建PDO对象时,有一些与数据库连接有关选项,可以将必要的几个选项组成数组传递给构造方法的第四个参数 driver_opts中,用来传递附加的调优参数到PDO货底层驱动程序。一些常用的使用选项如表:

选项名 描述
PDO::ATTR_AUTOCOMMIT 确定PDO是否关闭自定提交功能,设置FALSE值时关闭
PDO::ATTR_CASE 强制PDO获取的表字段字符的大小转换,或远原样使用列信息
PDO::ATTR_ERRMODE 设置错误处理的模式
PDO::ATTR_PERSISTENT 确定连接是否为持久连接,默认值为FALSE
PDO::ATTR_ORACCLE_NULLS 将返回的空字符串转换为SQL的NULL
PDO::ATTR_PREFETCH 设置应用程序提前获取的数据大小,以K字节单位
PDO::ATTR_TIMEOUT 设置超市之前等待的时间(秒数)
PDO::ATTR_SERVER_INFO 包含与数据库特有的服务器信息
PDO::ATTR_SERVER_VERSION 包含与数据库服务器版本号有关的信息
PDO::ATTR_CLIENT_VERSION 包含与数据库客户端版本号有关的信息
PDO::ATTR_CONNECTION_STATUS 包含数据库特有的与连接状态有关的信息

设置选项名为下表组成的关联数组,作为驱动程序特定的连接选项,传递给PDO构造方法的第四各参数中,在下面的实例中使用连接选项创建持久连接,持久连接的好处是能够避免在每个页面执行到打开和关闭数据库服务器连接,速度更快,如 MySQL数据库的一个进程创建了两个连接,PHP则会把原有连接与新的连接合并共享为一个连接,代码如下:

true);
try{
    $dbh = new PDO('mysql:host=localhost;dbname=test','dbuser','password',$opt); //使用$opt参数
}catch(PDOException $e){
    echo '连接失败:'.$e->getMessage();
}
?>

以上就是关于以多种方式调用构造方法创建PDO对象的所有内容,小伙伴们都理解了吗?可以在自己本地试一试!

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

129

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

77

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

81

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

60

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

444

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

15

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

12

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

5

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

550W粉丝大佬手把手从零学JavaScript
550W粉丝大佬手把手从零学JavaScript

共1课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号