M方法和D方法的区别
ThinkPHP 中M方法和D方法都用于实例化一个模型类,M方法 用于高效实例化一个基础模型类,而 D方法 用于实例化一个用户定义模型类。
使用M方法
如果是如下情况,请考虑使用 M方法:
- 对数据表进行简单的 CURD 操作而无复杂的业务逻辑时
- 只有个别的表有较为复杂的业务逻辑时,将 M方法 与实例化 CommonModel 类进行结合使用
M方法 甚至可以简单看着就是对参数表名对应的数据表的操作:
$User = M(‘User‘);
使用D方法
如果是如下情况,请考虑使用 D方法:
- 需要使用 ThinkPHP 模型中一些高级功能如自动验证功能(create()方法中实现)、关联模型等
- 业务逻辑比较复杂,且涉及的表众多
- 将业务逻辑定义在了自定义的模型类里面(Lib/Model目录下),而想在操作中实现这些业务逻辑
另外 D方法 不支持跨项目调用,需要使用:
$User = D(‘User‘, ‘Admin‘); // 实例化 Admin 项目下面的 User 模型 $User = D(‘Admin.User‘); // 启用了项目分组
提示
启用了项目分组后,Model 类并不必然对应着项目分组。多个项目组之间共有的模型类,统一放在 Model 目录下,可以直接使用D(‘ModelName‘) 实例化。而 D(‘User.UserInfo‘) 并不表示 User 一定是一个项目分组,也可以仅仅是对 Model 下文件的一个分类目录,D(‘User.UserInfo‘) 实例化的是 User 目录下的 UserInfo 模型类。
总结
M方法 和 D方法 都可以在模型类文件不存在的情况下直接使用的,但显然 M方法 更高效;但要使用模型类里面业务逻辑,就必须使用 D方法。
一个比较形象的比喻就是:M方法 就如一台刚装好操作系统的电脑,只能使用一些基本功能;而 D方法 就如在装好的系统上再安装了一些如 Office、QQ 等应用软件,功能更加强大,同时整个电脑运行速度也变慢了。
以上是对 M方法和D方法区别的一些总结,M方法 和 D方法 要根据实际情况来具体选择。
M和D的使用create()都一样:
1 // 实例化User模型 2 $User = M(‘User‘); 3 // 根据表单提交的POST数据创建数据对象 4 $User->create();
注意! 当$User->create();来到这一步时,他会自己接受表单提交过来的数据,但是前提是表单提交的数据的name必须要和数据库里面的字段名一样才行。
在没有使用save()或add()方法之前,数据还是可以修改的,如:
1 $User = M(‘User‘); 2 $User->create(); //创建User数据对象 3 $User->status = 1; // 设置默认的用户状态 4 $User->create_time = time(); // 设置用户的创建时间 5 $User->add(); // 把用户对象写入数据库
写入数据:
1 public function insert(){ 2 header("Content-Type:text/html; charset=utf-8"); 3 $Dao = M("User"); // 实例化模型类 4 5 // 数据对象赋值 6 $Dao->username = "小王"; 7 $Dao->password = md5("123456"); 8 $Dao->email = "[email protected]"; 9 $Dao->regdate = time(); 10 11 // 写入数据 12 if($lastInsId = $Dao->add()){ 13 echo "插入数据 id 为:$lastInsId"; 14 } else { 15 $this->error(‘数据写入错误!‘); 16 } 17 }
拿出来用:
.create方法可以对POST提交的数据进行处理(通过表中的字段名称与表单提交的名称对应关系自动封装数据实例),例如user表中有一个字段名叫"username",如果表单中有一个<input name="username" value="小明">,那么$User = M(‘User‘); $data = $User->create(); echo $data[‘username‘];就会输出"小明",不用你用$_POST[‘username‘]去接收。
使用create()方法,我们可以使用验证:
- 静态方式:在模型类里面通过$_validate属性定义验证规则。
- 动态方式:使用模型类的validate方法动态创建自动验证规则。
无论是什么方式,验证规则的定义是统一的规则,定义格式为:
array(
array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),
array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),
......
);
以上验证的代码必须写在Model文件夹里面,且文件名以 ‘表名(第一个字符大写)Model.class.php‘ ,验证的规则自己看手册。
自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证。