最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-09 09:00:02
文档

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

以多种方式调用构造方法创建PDO对象:以多种方式调用构造方法创建PDO对象可以以多种昂方式调构造方法创建PDO对象,下面以连接MySQL 和 Oracle 服务器为例,分别介绍构造方法的多种调用方式。一、将参数嵌入到构造函数在下面的连接Oracle 服务器的示例中,在DSN字符串中加载OCI驱动程序并指定里
推荐度:
导读以多种方式调用构造方法创建PDO对象:以多种方式调用构造方法创建PDO对象可以以多种昂方式调构造方法创建PDO对象,下面以连接MySQL 和 Oracle 服务器为例,分别介绍构造方法的多种调用方式。一、将参数嵌入到构造函数在下面的连接Oracle 服务器的示例中,在DSN字符串中加载OCI驱动程序并指定里

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

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

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

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

<?php
try{
 $dbh = new PDO("OCI:dbname = accounts;charset=UTF8","scott","tiger");
}catch (PDOException $e){
 echo "数据库连接失败:".$e->getMessage();
}
?>

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

<?php
$dbms = "mysql"; // 数据库的类型
$dbName ="php_cn"; //使用的数据库名称
$user = "root"; //使用的数据库用户名
$pwd = "root"; //使用的数据库密码
$host = "localhost"; //使用的主机名称
$dsn = "$dbms:host=$host;dbname=$dbName";
try {
 $pdo = new PDO($dsn, $user, $pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
}catch (PDOException $e){
 echo "数据库连接失败:".$e->getMessage();
}
?>

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

二、将参数存放在文件中

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

<?php
try{
 $dbh = new PDO('uri:file:///usr/localhost/dbconnect','webuser','password');
}catch(PDOException $e){
 echo '连接失败:'.$e->getMessage();
}
?>

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

三、引用 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构造方法时,在第一个参数中使用这个别名,如下所示:

<?php
try{
 $dbh = new PDO('oraclepdo','scott','tiger');//使用php.ini文件中的oraclepdo 别名
}catch(PDOException $e){
 echo '连接失败:'.$e->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则会把原有连接与新的连接合并共享为一个连接,代码如下:

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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

以多种方式调用构造方法创建PDO对象:以多种方式调用构造方法创建PDO对象可以以多种昂方式调构造方法创建PDO对象,下面以连接MySQL 和 Oracle 服务器为例,分别介绍构造方法的多种调用方式。一、将参数嵌入到构造函数在下面的连接Oracle 服务器的示例中,在DSN字符串中加载OCI驱动程序并指定里
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top