thinkphp--create()的使用方法(个人感悟)

M方法和D方法的区别

ThinkPHP 中M方法和D方法都用于实例化一个模型类,M方法 用于高效实例化一个基础模型类,而 D方法 用于实例化一个用户定义模型类。

使用M方法

如果是如下情况,请考虑使用 M方法:

  1. 对数据表进行简单的 CURD 操作而无复杂的业务逻辑时
  2. 只有个别的表有较为复杂的业务逻辑时,将 M方法 与实例化 CommonModel 类进行结合使用

M方法 甚至可以简单看着就是对参数表名对应的数据表的操作:

$User = M(‘User‘);

使用D方法

如果是如下情况,请考虑使用 D方法:

  1. 需要使用 ThinkPHP 模型中一些高级功能如自动验证功能(create()方法中实现)、关联模型等
  2. 业务逻辑比较复杂,且涉及的表众多
  3. 将业务逻辑定义在了自定义的模型类里面(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()方法,我们可以使用验证:

  1. 静态方式:在模型类里面通过$_validate属性定义验证规则。
  2. 动态方式:使用模型类的validate方法动态创建自动验证规则。

无论是什么方式,验证规则的定义是统一的规则,定义格式为:

  1. array(
  2. array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),
  3. array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),
  4. ......
  5. );

以上验证的代码必须写在Model文件夹里面,且文件名以  ‘表名(第一个字符大写)Model.class.php‘ ,验证的规则自己看手册。

自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证。

时间: 2024-10-29 19:12:27

thinkphp--create()的使用方法(个人感悟)的相关文章

ThinkPHP 更新数据 save方法

ThinkPHP save() 方法 ThinkPHP 中使用 save() 方法来更新数据库,并且也支持连贯操作的使用. 例子: public function update(){ header("Content-Type:text/html; charset=utf-8"); $Dao = M("User"); // 需要更新的数据 $data['email'] = '[email protected]'; // 更新的条件 $condition['userna

thinkphp模版调用函数方法

原文:thinkphp模版调用函数方法 {变量|函数1|函数2|函数3=参数1,参数2,参数3,###} ###为第4个参数,代表变量替换为第4个参数 举例: {$username|substr=0,3}取标题中前3个字符 {$times|date='Y-m-d H:i:s',###}将times时间戳转换为日期格式 ================================================== 冒号执行函数的用法:输出方法并执行返回值 {:U('user/insert')

THINKPHP短链接设置方法(路由设置)

//路由设置(短链接设置)'URL_ROUTER_ON' => true,'URL_ROUTE_RULES' => array('log' => 'Login/index','admin' => 'Login/admin','reg' => 'Login/register', 'c/:id' => 'Index/index/user' '/^C_(\d+)$/' => 'Index/index/user?id=:1'), 长链接:http://localhost/

深入解析thinkphp中的addAll方法

原因: 在做中控系统中遇到了一个给用户批量分配角色的问题,刚开始想到的是循环插入,但立马给否定了,循环操作数据库开发者的大忌啊,于是查找手册找到数据写入看到批量操作:addAll(),测试成功,以为万事大吉了,但当第二次操作时提示失败,找原因,原来是数据库中已经存在的数据addAll()没有覆盖导致了错误 解决方法: 查找Thinkphp源码翻到Library/Think/Model.class.php找到了addAll方法:public function addAll($dataList,$o

ThinkPHP单字母函数(快捷方法)使用总结

ThinkPHP单字母函数(快捷方法)使用总结 投稿:shichen2014 字体:[增加 减小] 类型:转载 时间:2014-07-23 这篇文章主要介绍了ThinkPHP单字母函数(快捷方法)使用总结,对ThinkPHP的快捷方法做了针对性的归纳总结,需要的朋友可以参考下 在ThinkPHP中有许多使用简便的单字母函数(即快捷方法),可以很方便开发者快速的调用,但是字母函数却不方便记忆,本文将所有的字母函数总结一下,以方便以后查找. 1.U() URL组装 支持不同URL模式 ? 1 U($

ThinkPHP 模板输出 display 方法

默认输出 模板默认输出是指输出指令 display 方法中不带任何参数,系统默认输出对应模板. 格式: $this->display(); 输出对应的模板: TPL/模板默认主题/[分组名/]模块名/操作名+模板后缀 其他输出 输出当前模块的其他操作模板 格式: $this->display('操作名'); 例子: <?php class IndexAction extends Action{     public function index(){         //输出当前模块其他

thinkphp访问其他数据库方法

M('[基础模型名:]模型名','数据表前缀','数据库连接信息') $User = M('User','think_','mysql://user_a:[email protected]:3306/thinkphp'); 在config.php增加 'DB_CONFIG2' => 'mysql://root:localhost@115.*.*.*/tbname', 使用方法 M('User','think_','DB_CONFIG2'); 或者 M()->db(2,"DB_CONF

ThinkPHP:create()方法有什么用呢?

1.create方法可以对POST提交的数据进行处理(通过表中的字段名称与表单提交的名称对应关系自动封装数据实例),例如user表中有一个字段名叫"username",如果表单中有一个<input name="username" value="小明">,那么$User = M('User'); $data = $User->create(); echo $data['username'];就会输出"小明",不

ThinkPHP框架 【 AJAX方法返回 】 例子:简单添加一条数据 和 查询一个表里的数据

注:thinkphp使用ajax和之前使用ajax的方法一样,不同点在于之前的ajax中的url指向了一个页面,而thinkphp里面的url需要指向一个操作方法. 在模块控制器Controller文件夹里创建一个 AjaxController.class.php <?php namespace Admin\Controller; use think\Controller; class AjaxController extends Controller{ public function Ajax