本文主要是介绍Yii 框架读书笔记(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
最近陆陆续续的看了点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();
1. 建立数据库连接
这个framework会动态的建立连接和断开连接,所以在数据库操作的时候就不需要加入额外的代码来操作数据库。
默认情况下,AR假定db应用组件提供了所需的CDbConnection数据库连接实例。如下应用配置提供了一个例子:
return array('components'=>array('db'=>array('class'=>'system.db.CDbConnection','connectionString'=>'sqlite:path/to/dbfile',// 开启表结构缓存(schema caching)提高性能// 'schemaCachingDuration'=>3600,),),
);
ps:上面的代码我还没有真正得到是什么意思,以后用到了再来补充。
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';}
}
默认情况下,AR类的名字和数据表的名字相同,如果想改名字的话需要重写tableName()方法。
还可以通过重写primaryKey()方法来指定primary key
public function primaryKey()
{return 'id';// 对于复合主键,要返回一个类似如下的数组// return array('pk1', 'pk2');
}
3. 创建记录
在表中也可以使用静态默认值,就是一创建好,这个值就已经在那了,例如:
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);
返回的post是一个instance,可以访问其属性。如果没有找到的话返回的是null。
其中$condition是SQL语句,$params是参数数组,对应$condition里面的占位符。也可以用condition来制定更复杂的条件。
当然也可以用一个变量来规定更复杂的查询条件。
这篇关于Yii 框架读书笔记(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!