以多种方式调用构造方法创建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对象的所有内容,小伙伴们都理解了吗?可以在自己本地试一试!
Atas ialah kandungan terperinci 以多种方式调用构造方法创建PDO对象. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!