最近陆陆续续的看了点Yii框架的东西,冰山一角应该都不到,稍微理解点的东西先记一下,免得后面又忘记了。
首先Yii框架是一个MVC模型,并且给予HTTP协议,因此是没有记忆的。当用户访问一个url的时候,会执行Controller的一个default的动作,
如果URL是:host / path / xxx /yyy,那么这个default的动作就是 xxxController.php 中的 actionyyy(), module为path。
Yii框架的数据库操作:
Yii的数据库操作主要用到两种:DAO和Active Record
目前我只用到了Active Record, 所以先总结一下用法:
源:yiichina-AR教程
AR和数据库的对应关系:
AR类: | 数据表 |
类的属性: | 数据表的列 |
对象: | 表中的一行 |
AR方法实现: | 常见的CRUD操作 |
例:我们使用下面的数据库作为例子
CREATE TABLE tbl_post ( id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, title VARCHAR(128) NOT NULL, content TEXT NOT NULL, create_time INTEGER NOT NULL );
我们可以用以下代码向tbl_post表中插入一个新行
$post=new Post; $post->title='sample post'; $post->content='post body content'; $post->save();
这个framework会动态的建立连接和断开连接,所以在数据库操作的时候就不需要加入额外的代码来操作数据库。
默认情况下,AR假定db应用组件提供了所需的CDbConnection数据库连接实例。如下应用配置提供了一个例子:
return array( 'components'=>array( 'db'=>array( 'class'=>'system.db.CDbConnection', 'connectionString'=>'sqlite:path/to/dbfile', // 开启表结构缓存(schema caching)提高性能 // 'schemaCachingDuration'=>3600, ), ), );
2. 定义AR类
一个AR类是CActiveRecord的子类,下面这个例子代表了tbl_post表的AR类的最简代码:
class Post extends CActiveRecord { public static function model($className=__CLASS__) { return parent::model($className); } public function tableName() { return 'tbl_post'; } }
还可以通过重写primaryKey()方法来指定primary key
public function primaryKey() { return 'id'; // 对于复合主键,要返回一个类似如下的数组 // return array('pk1', 'pk2'); }
在表中也可以使用静态默认值,就是一创建好,这个值就已经在那了,例如:
class Post extends CActiveRecord { public $title='please enter a title'; ...... } $post=new Post; echo $post->title; // 这儿将显示: please enter a title
4. 读取记录
读数据:调用父类中的静态方法model()->find()找到符合条件的instance
// 查找满足指定条件的结果中的第一行 $post=Post::model()->find($condition,$params); // 查找具有指定主键值的那一行 $post=Post::model()->findByPk($postID,$condition,$params); // 查找具有指定属性值的行 $post=Post::model()->findByAttributes($attributes,$condition,$params); // 通过指定的 SQL 语句查找结果中的第一行 $post=Post::model()->findBySql($sql,$params);
其中$condition是SQL语句,$params是参数数组,对应$condition里面的占位符。也可以用condition来制定更复杂的条件。
当然也可以用一个变量来规定更复杂的查询条件。