标签:
YII中实现两种类型的模型,分别是表单模型和活动记录。在持久化数据方面,YII只实现了活动记录,对于复杂的数据关系可以用框架提供的DAO来自己写model,对应集成doctrine这样的ORM还没有仔细研究过。
ar模型
框架中的model是CModel子类,CModel主要是一些验证与错误处理,并实现迭代器和数组访问接口,活动记录模型CActiveRecord是AR模型的基类。
每个AR类代表一个单独的数据表,一个AR实例则代表那个表中的一行。AR是一种对象关系映射(ORM)的设计模式,它负责数据持久化.
封装了数据库CURD操作,同时它是一种领域模型(Domain Model), 封装了部分业务逻辑。一个AR类中包括了表结构(Table
Schema),约束以及 CURD
实例化model有两种方法,直接new一个新的实例,或者用静态方法mode(),后者与前者的区别是略过构造函数执行的代码(主要是避免元数据的多次获取),用静态方法mode()创建ar对象经过一下步骤:
上 面流程下来会遇到一个问题,每一次创建model都会执行"SHOW COLUMNS FROM $tableName"和"SHOW CREATE TABLE $tableName"的查询,在高并发下会影响性能。可以在主配置文件中的数据库配置中添加schemaCachingDuration和 schemaCacheID的配置来缓存数据库schema,前者是设置缓存的时间,后者是缓存组件的id,但缓存带来的问题是修改数据库中表结构不能立 即生效,所以在生产环境下写一个刷新缓存的脚本是又必要的。
DAO
ar模型带来的好处是将开发中SQL语句的编写减到最小,ar模型既封装了数据库记录的状态和持久化到数据库的访问方
法,也封装了业务逻辑,这在关系不是很复杂的应用中带来的好处显而易见,但如果数据库关系复杂,业务逻辑复杂,有必要将对数据的操作单独提出来,YII中
的DAO就是将业务逻辑和数据交换分开,也降低了业务和数据库的耦合性。
YII中DAO基于PDO,统一的接口可以访问不同的数据库管理系统。在框架中CDbConnection、CDbCommand、CdbDataReader、CDbTransaction类分别管了数据量的连接、命令、读取和事务。
YII还对数据库的schema进行映射,一个数据库是对应一个对象,一个表对应一个对象,一列对应一个对象,这些对象分别封装其对应schema的一些操作。
标签:
原文地址:http://www.cnblogs.com/sunscheung/p/4827122.html