Welcome 微信登录

首页 / 网页编程 / PHP / PHP开发框架Yii Framework教程(24) 数据库-DAO示例

PHP开发框架Yii Framework教程(24) 数据库-DAO示例2013-02-01 csdn mapdigit据访问对象(DAO) 对访问存储在不同数据库管理系统(DBMS)中的数据提供了一个通用的API。 因此,在将底层 DBMS 更 换为另一个时,无需修改使用了 DAO 访问数据的代码。

Yii DAO 基于 PHP Data Objects (PDO) 构建。它是一个为众多 流行的DBMS提供统一数据访问的扩展,这些 DBMS 包括 MySQL, PostgreSQL 等等。因此,要使用 Yii DAO,PDO 扩展和特定的 PDO 数据库驱动(例如PDO_MYSQL) 必须安装。

Yii DAO 主要包含如下四个类:

CDbConnection: 代表一个数据库 连接。

CDbCommand: 代表一条通过数据库执行的 SQL 语句。

CDbDataReader: 代表一个只向前移动的,来自一个查询结果集中的行的流。

CDbTransaction: 代表一个数据库事务。

下面,我们介绍 Yii DAO 在不同场景中的应用。 1. 建立数据库连接

要建立一个数据库连接,创建一个 CDbConnection 实例并将其激活。 连接到数据库需要一个数据源 的名字(DSN)以指定连接信息。用户名和密码也可能会用到。 当连接到数据库的过程中发生错误时 (例如,错误的 DSN 或无 效的用户名/密码),将会抛出一个异常。

$connection=new CDbConnection($dsn,$username,$password); // 建立连接。你可以使用try...catch 捕获可能抛出的异常 $connection->active=true; ...... $connection->active=false;// 关闭连接
DSN 的格式取决于所使用的 PDO 数据库驱动。总体来说, DSN 要含 有 PDO 驱动的名字,跟上一个冒号,再跟上驱动特定的连接语法。可查阅 PDO 文档 获取更多信息。 下面是一个常用DSN格式 的列表。

SQLite: sqlite:/path/to/dbfile

MySQL: mysql:host=localhost;dbname=testdb

PostgreSQL: pgsql:host=localhost;port=5432;dbname=testdb

SQL Server: mssql:host=localhost;dbname=testdb

Oracle: oci:dbname=//localhost:1521/testdb

由于 CDbConnection 继承自 CApplicationComponent,我们也可以将其作为一个 应用组件 使用。要这样做的话, 请在 应 用配置 中配置一个 db (或其他名字)应用组件如下:

本例使用MySQL chinook 数据库,修改 protected/config/main.php

"components"=>array( "db"=>array( "class"=>"CDbConnection", "connectionString"=>"mysql:host=localhost;dbname=chinook", "username"=>"root", "password"=>"password", "emulatePrepare"=>true,// needed by some MySQL installations ), ),
然后我们就可以通过 Yii::app()->db 访问数据库连接了。它已经被自动激活了,除非我们特意配置了 CDbConnection::autoConnect 为 false。通过这种方式,这个单独的DB连接就可以在我们代码中的很多地方共享。

2. 执行 SQL 语句

数据库连接建立后,SQL 语句就可以通过使用 CDbCommand 执行了。你可以通过使用指定的SQL语句作为 参数调用 CDbConnection::createCommand() 创建一个 CDbCommand 实例。

为简单起见,我们使用Chinook数据库中的 Employee表,修改DataModel

class DataModel { public $employeeId; public $firstName; public $lastName; public $title; public $address; public $email; }
注:创建DataModel这一步可以选。