Yii操作数据库的3种方法
2015-01-24信息快讯网
这篇文章主要介绍了Yii操作数据库的3种方法,需要的朋友可以参考下
一、执行原生太SQL的PDO方式。$sql = "";//原生态sql语句 xx::model()->dbConnection->createCommand($sql)->execute();
二、Active Record方式
(1)New 方式
$post=new Post; $post->title='sample post'; $post->content='post body content'; $post->save();
(2)Criteria方式
也可以使用 $condition 指定更复杂的查询条件。 不使用字符串,我们可以让 $condition 成为一个 CDbCriteria 的实例,它允许我们指定不限于 WHERE 的条件。
$criteria=new CDbCriteria; $criteria->select='title'; // 只选择 'title' 列 $criteria->condition='postID=:postID'; $criteria->params=array(':postID'=>10); $post=Post::model()->find($criteria);
一种替代 CDbCriteria 的方法是给 find 方法传递一个数组。 数组的键和值各自对应标准(criterion)的属性名和值,上面的例子可以重写为如下:
$post=Post::model()->find(array( 'select'=>'title', 'condition'=>'postID=:postID', 'params'=>array(':postID'=>10), ));
当一个查询条件是关于按指定的值匹配几个列时,我们可以使用 findByAttributes()。我们使 $attributes 参数是一个以列名做索引的值的数组。在一些框架中,此任务可以通过调用类似 findByNameAndTitle 的方法实现。虽然此方法看起来很诱人,但它常常引起混淆、冲突和比如列名大小写敏感的问题。
三、Query Builder 方式
$user = Yii::app()->db->createCommand() ->select('id, username, profile') ->from('tbl_user u') ->join('tbl_profile p', 'u.id=p.user_id') ->where('id=:id', array(':id'=>$id)) ->queryRow();
PHP中使用json数据格式定义字面量对象的方法
PHP采用自定义函数实现遍历目录下所有文件的方法
浅谈php函数serialize()与unserialize()的使用方法
PHP将回调函数作用到给定数组单元的方法
PHP防止表单重复提交的几种常用方法汇总
yii实现创建验证码实例解析
yii操作session实例简介
yii实现级联下拉菜单的方法
YII中assets的使用示例
Yii使用CLinkPager分页实例详解
php的webservice的wsdl的XML无法显示问题的解决方法
php导出excel格式数据问题
PHP中对于浮点型的数据需要用不同的方法解决
php中3种方法删除字符串中间的空格
CodeIgniter框架中_remap()使用方法2例
PHP_Cooikes不同页面无法传递的解决方法
PHP程序漏洞产生的原因分析与防范方法说明
解析yii数据库的增删查改
在yii中新增一个用户验证的方法详解
浅析Yii中使用RBAC的完全指南(用户角色权限控制)
Yii PHP Framework实用入门教程(详细介绍)
深入解析yii权限分级式访问控制的实现(非RBAC法)