发布于 2015-01-24 02:07:29 | 1140 次阅读 | 评论: 0 | 来源: PHPERZ

这里有新鲜出炉的YII 2.0教程,程序狗速度看过来!

Yii高性能PHP框架

Yii Framework是一个基于组件、用于开发大型 Web 应用的高性能 PHP 框架。Yii提供了今日Web 2.0应用开发所需要的几乎一切功能。Yii是最有效率的PHP框架之一。Yii是创始人薛强的心血结晶,于2008年1月1日开始开发。


本文为大家介绍了Yii框架操作数据库的三种方式及优缺点对比,感兴趣的同学参考下吧。

一,YII操作数据的方式

1,PDO方式。

$sql = "";//原生态sql语句
xx::model()->dbConnection->createCommand($sql)->execute();


2,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 的方法实现。虽然此方法看起来很诱人, 但它常常引起混淆,冲突和比如列名大小写敏感的问题。
 

3,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();

二,三种操作数据库的方式优缺点对比

一、在用好AcitveRecord的情况下,即不要让其生成比较二的SQL查询方式,我的经验,不必过分在意那点时间性能上的区别的。对于大数据查询,内存空间上的话,在yii2中可以使用toArray()来节省内存消耗。

二、ActiveRecord之于PDO的长处在于其方便。

一个是相比于书写SQL语句,用ActiveRecord要简单一点,更重要的是不容易出错。

二是提供了许多SQL语句之外的便利,比如参数过滤、绑定等等。这个web开发中你总要遇到吧,一个SQL语句一个SQL语句的写,代码复用程度不高不说,还容易某个地方忘记过滤了,形成安全隐患。

三、 Yii2中已经有Query,性能上优于ActiveRecord,可以作为替代。当然,方便与效率是硬币的两面,其使用上不如ActiveRecord 方便。但在项目中我的经验是Query的使用频率仅略少于ActiveRecord,个人认为Query/ActiveQuery是Yii2中引入的一个 激动人心的新feature。

四、前面几条说的是ActiveRecord的应用场景。对于PDO,如果要用的话, 应该是对于比较复杂的SQL操作,比如一两句话写不清楚的。这种情况下,使用ActiveRecord来构建,其复杂程度不亚于直接写SQL,那么可以考 虑使用PDO。但我印象中,如果项目中使用的SQL语句很复杂,会被写成DB的View或者存储过程,所以,感觉PDO使用并不多,可以说是极少的。

五、追求更高效率的话,个人也不认为应该过多使用PDO,这给后期维护带来极大的难度。倒是可以考虑优化SQL查询,优化索引和表结构,使用缓存等。值得一提的是,使用缓存,是最简单、直接,成效也最为明显的手段。

六、永远没必要过早考虑性能问题。



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务