Heim > php教程 > php手册 > Yii使用find findAll查找出指定字段的实现方法

Yii使用find findAll查找出指定字段的实现方法

WBOY
Freigeben: 2016-06-13 08:59:09
Original
2002 Leute haben es durchsucht

Yii使用find findAll查找出指定字段的实现方法

这篇文章主要介绍了Yii使用find findAll查找出指定字段的实现方法,非常实用的技巧,需要的朋友可以参考下。

用过Yii的朋友都知道,采用如下方法:

modelName::model()->find() //找出的是一个对象
modelName::model()->findALL() //找出的是一个对象集合的数组 
Nach dem Login kopieren

可以找出对象与对象集合的数组,那么如何找出我所需要的字段的数据,而不是全部字段的数据呢?之前我是这么做的:

$criteria=new CDbCriteria;
$criteria->select='username,id,email';
$criteria->order='id DESC';
$users=modelName::model()->findAll( $criteria );
Nach dem Login kopieren

后台无意中看到别人有这么写的,方法很不错:

$users=modelName::model()->findAll(array('select'=>array('username','id','email'),'order'=>'id DESC'));
Nach dem Login kopieren

测试后发现果然可以用,那么find也可以这么操作:

$user=modelName::model()->find(array('select'=>array('username','id','email'),'order'=>'id DESC','condition'=>'id='.$id, ));
Nach dem Login kopieren

当然了,这么做肯定不安全了,换成下面的方法同样可以:

$users=$this->user->find(array('select'=>array('id','username','email'),'order'=>'id DESC','condition'=>'state=:state AND id=:id','params'=>array(':state'=>'1',':id'=>'2')));
Nach dem Login kopieren

同理用findAll测试了也是可以的。

结论:

通过这种方法能够很方便的获取所需要的数据,当然需要分页的时候还是 需要 new 一下 CDbCriteria 的。

您可能感兴趣的文章

  • Yii查看(输出)当前页面执行的sql语句
  • Yii framework框架之模块开发分析
  • Yii控制器动作参数绑定处理
  • yii 数据库添加,修改,删除相关操作总结
  • 将yii对象结果转为数组的方法
  • yii框架目录结构详细分析说明
  • yii框架缓存知识总结
  • yii数据库查询操作总结
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage