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 框架读书笔记(一))