Yii使用技巧大汇总(8)

class ExtWindow extends CApplicationComponent{ private $title = 'title'; public $oldtitle; public function getTitle(){ return $this->title ? $this->title : 'old title<br />'; } public function setTitle($title){ echo '=='.$this->oldtitle.'=='; $this->oldtitle = $this->title; $this->title = $title; if($this->hasEventHandler('onTitleChange')){ $event =new CEvent($this); $this->raiseEvent('onTitleChange', $event); } } //必须有这么个方法,其和raiseEent中的事件一样,具体看代码 public function onTitleChange($event){ } }

<?php class Window extends CBehavior{ public function events(){ return array_merge(parent::events(),array( 'onTitleChange'=>'titleChange', )); } public function titleChange($event){ echo $event->sender->title; echo 'event TitleChange is handled in Behavior<br />'; echo $this->owner->title; } public function titleOld(){ echo '<br />old title is is '.$this->owner->oldtitle; } }

main.php中的写法

'ExtWin'=>array( 'class' => 'ExtWindow', 'oldtitle'=>'我是旧的', 'behaviors'=>array('win'=>'application..behavior.Window')

一对多,多对多的关联时最后的参数 together说明

如果为false,分开查多个语句
如果为true,强制生成一个语句
如果没有设置,分页页生成多个语句,不分页时生成一个语句
),
多对多时,查询时,中间表的名子叫 (关联名_关联名)
with选项的作用是eager loading
together的作用是 要不要形成一个语句

当是一个sql语句是记录会有重复,这时候分页分出现相同的记录,加上group=>true即可,

只要弄明白了,你生成的sql是一条还是多条sql就明白在多对多查询时的结果了

两个表不是用主键关联

复制代码 代码如下:

'user' => array(self::BELONGS_TO, 'OaskUser', '','on'=>'name=userName', 'select'=>'TrueName'),


表带talbeprefix是,多对关联,键的写法

复制代码 代码如下:

'categories'=>array(self::MANY_MANY,'Category','{{post_category}}(post_id,category_id)'),

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/2f8106786391352ef2279db1bd51a4b1.html