• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 以多种方式调用构造方法创建PDO对象

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

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了构造方法,PDO对象等相关知识,希望本文的分享对您有所帮助
以多种方式调用构造方法创建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();
}
?>

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

以上就是以多种方式调用构造方法创建PDO对象的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2017-05-11centos下安装mysql服务器的方法
  • 2018-12-05Mysql如何跳过权限进行操作的步骤
  • 2018-12-05图片上的是mysql哪一种可视化工具?
  • 2018-12-05MySQL SQL命令速查
  • 2017-05-11MySQL union 语法代码示例分析
  • 2018-12-05mysql merge union merge sort_union 的不同
  • 2018-12-05什么是mysql子查询?如何利用子查询进行过滤?
  • 2018-12-05MySQL修改账号的IP限制条件实例分享
  • 2018-12-05mybatis分页插件pageHelper实例详解
  • 2017-05-11彻底卸载MySQL的方法分享

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql数据库replace、regexp的用法
    • MySQL创建存储过程并循环添加记录方法详解
    • Java如何连接Mysql数据库
    • Mysql Sql语句注释大全实例分享
    • mysql 触发器用法实例分享
    • MySQL基础教程3 — 数据类型之字符串类型
    • 自用mysql自带命令实现数据库备份还原的方法
    • MYSQL无法启动提示: Default storage engine (InnoDB) is not available的解决方法
    • mysql Innodb表空间卸载、迁移、装载的使用方法
    • php中获取系统信息的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有