Yii学习总结之数据访问对象 (DAO)
《Yii学习总结之数据访问对象 (DAO)》要点: Yii提供了强大的数据库编程支持.Yii数据拜访对象(DAO)建立在PHP的数据对象(PDO)extension上,使得在一个单一的统一的接口可以拜访不同的数据库管理系统(DBMS).使用Yii的DAO开发的应用程序可以很容易地切换使用不同的数据库管理系统,而不需要修改数据拜访代码.PHP教程 数据拜访对象(DAO) 对拜访存储在不同数据库管理系统(DBMS)中的数据提供了一个通用的API. 因此,在将底层 DBMS 更换为另一个时,无需修改使用了 DAO 拜访数据的代码.PHP教程 Yii DAO 基于 PHP Data Objects (PDO) 构建.它是一个为众多流行的DBMS提供统一数据拜访的扩展,这些 DBMS 包括 MySQL,PostgreSQL 等等.因此,要使用 Yii DAO,PDO 扩展和特定的 PDO 数据库驱动(例如PDO_MYSQL) 必须安装.PHP教程 Yii DAO 主要包括如下四个类:PHP教程 CDbConnection: 代表一个数据库连接. 1. 建立数据库连接
代码如下:
$connection=new CDbConnection($dsn,$username,$password); // 建立连接.你可以使用? try...catch 捕捉可能抛出的异常 $connection->active=true; ...... $connection->active=false;? // 关闭连接 DSN 的格式取决于所使用的 PDO 数据库驱动.总体来说,DSN 要含有 PDO 驱动的名字,跟上一个冒号,再跟上驱动特定的连接语法.可查阅 PDO 文档 获取更多信息. 下面是一个常用DSN格式的列表.PHP教程
代码如下:
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 (或其他名字)应用组件如下:PHP教程
代码如下:
array( ??? ...... ??? 'components'=>array( ??????? ...... ??????? 'db'=>array( ??????????? 'class'=>'CDbConnection', ??????????? 'connectionString'=>'mysql:host=localhost;dbname=testdb', ??????????? 'username'=>'root', ??????????? 'password'=>'password', ??????????? 'emulatePrepare'=>true,? // needed by some MySQL installations ??????? ), ??? ), ) 然后我们就可以通过 Yii::app()->db 拜访数据库连接了.它已经被自动激活了,除非我们特意配置了CDbConnection::autoConnect 为 false.通过这种方式,这个单独的DB连接就可以在我们代码中的很多地方共享.PHP教程 2. 执行 SQL 语句
代码如下:
$connection=Yii::app()->db;?? // 假设你已经建立了一个 "db" 连接 // 如果没有,你可能必要显式建立一个连接: // $connection=new CDbConnection($dsn,$password); $command=$connection->createCommand($sql); // 如果必要,此 SQL 语句可通过如下方式修改: // $command->text=$newSQL; 一条 SQL 语句会通过 CDbCommand 以如下两种方式被执行:PHP教程 execute(): 执行一个无查询 (non-query)SQL语句,例如 INSERT,UPDATE 和 DELETE .如果胜利,它将返回此执行所影响的行数.PHP教程 query(): 执行一条会返回若干行数据的 SQL 语句,例如 SELECT. 如果成功,它将返回一个CDbDataReader 实例,通过此实例可以遍历数据的结果行.为简便起见,(Yii)还实现了一系列queryXXX() 办法以直接返回查询结果.PHP教程 执行 SQL 语句时如果发生差错,将会抛出一个异常.PHP教程
代码如下:
$rowCount=$command->execute();?? // 执行无查询 SQL $dataReader=$command->query();?? // 执行一个 SQL 查询 $rows=$command->queryAll();????? // 查询并返回结果中的所有行 $row=$command->queryRow();?????? // 查询并返回结果中的第一行 $column=$command->queryColumn(); // 查询并返回结果中的第一列 $value=$command->queryScalar();? // 查询并返回结果中第一行的第一个字段 3. 获取查询结果
代码如下:
$dataReader=$command->query(); // 重复调用 read() 直到它返回 false while(($row=$dataReader->read())!==false) { ... } // 使用 foreach 遍历数据中的每一行 foreach($dataReader as $row) { ... } // 一次性提取所有行到一个数组 $rows=$dataReader->readAll(); 注意: 不同于 query(),所有的 queryXXX() 办法会直接返回数据. 例如,queryRow() 会返回代表查询结果第一行的一个数组.PHP教程 4. 使用事务 开始事务.
代码如下:
$transaction=$connection->beginTransaction(); try { ??? $connection->createCommand($sql1)->execute(); ??? $connection->createCommand($sql2)->execute(); ??? //.... other SQL executions ??? $transaction->commit(); } catch(Exception $e) // 如果有一条查询失败,则会抛出异常 { ??? $transaction->rollBack(); } 5. 绑定参数 参数占位符可以是命名的 (表现为一个唯一的标记) 或未命名的 (表现为一个问号).调用CDbCommand::bindParam() 或 CDbCommand::bindValue() 以使用实际参数替换这些占位符. 这些参数不需要使用引号引起来:底层的数据库驱动会为你搞定这个. 参数绑定必需在 SQL 语句执行之前完成.PHP教程
代码如下:
// 一条带有两个占位符 ":username" 和 ":email"的 SQL $sql="INSERT INTO tbl_user (username,email) VALUES(:username,:email)"; $command=$connection->createCommand($sql); // 用实际的用户名替换占位符 ":username" $command->bindParam(":username",PDO::PARAM_STR); // 用实际的 Email 替换占位符 ":email" $command->bindParam(":email",$email,PDO::PARAM_STR); $command->execute(); // 使用新的参数集插入另一行 $command->bindParam(":username",$username2,PDO::PARAM_STR); $command->bindParam(":email",$email2,PDO::PARAM_STR); $command->execute(); 办法 bindParam() 和 bindValue() 非常相似.唯一的区别就是前者使用一个 PHP 变量绑定参数,而后者使用一个值.对于那些内存中的大数据块参数,处于性能的考虑,应优先使用前者.PHP教程 关于绑定参数的更多信息,请参考 相关的PHP文档.PHP教程 6. 绑定列
代码如下:
$sql="SELECT username,email FROM tbl_user"; $dataReader=$connection->createCommand($sql)->query(); // 使用 $username 变量绑定第一列 (username) $dataReader->bindColumn(1,$username); // 使用 $email 变量绑定第二列 (email) $dataReader->bindColumn(2,$email); while($dataReader->read()!==false) { ??? // $username 和 $email 含有当前行中的 username 和 email } 7. 使用表前缀 要使用表前缀,配置 CDbConnection::tablePrefix 属性为所希望的表前缀. 然后,在 SQL 语句中使用{{TableName}} 代表表的名字,此中的 TableName 是指不带前缀的表名. 例如,如果数据库含有一个名为tbl_user 的表,而 tbl_ 被配置为表前缀,那我们就可以使用如下代码执行用户相关的查询:PHP教程
代码如下:
$sql='SELECT * FROM {{user}}'; $users=$connection->createCo妹妹and($sql)->queryAll(); 《Yii学习总结之数据访问对象 (DAO)》是否对您有启发,欢迎查看更多与《Yii学习总结之数据访问对象 (DAO)》相关教程,学精学透。编程之家 52php.cn为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |