ThinkPHP CURD方法的data方法也是模型类的连贯操作方法之一,用于设置当前要操作的数据对象的值,很多开发人员却并不太习惯用这个方法,今天来讲解下如何用好data方法。
具体用法如下:
1.写操作
通常情况下我们都是通过create方法或者赋值的方式生成数据对象,然后写入数据库,例如:
$Model = D('User'); $Model->create(); // 这里略过具体的自动生成和验证判断 $Model->add();
又或者直接对数据对象赋值,例如:
$Model = M('User'); $Model->name = '流年'; $Model->email = 'thinkphp@qq.com'; $Model->add();
那么data方法则是直接生成要操作的数据对象,例如:
$Model = M('User'); $data['name'] = '流年'; $data['email'] = 'thinkphp@qq.com'; $Model->data($data)->add();
注意:如果我们同时使用create方法和data创建数据对象的话,则后调用的方法有效。
data方法支持数组、对象和字符串,对象方式如下:
$Model = M('User'); $obj = new stdClass; $obj->name = '流年'; $obj->email = 'thinkphp@qq.com'; $Model->data($obj)->add();
字符串方式用法如下:
$Model = M('User'); $data = 'name=流年&email=thinkphp@qq.com'; $Model->data($data)->add();
也可以直接在add方法中传入数据对象来新增数据,例如:
$Model = M('User'); $data['name'] = '流年'; $data['email'] = 'thinkphp@qq.com'; $Model->add($data);
但是这种方式data参数只能使用数组。
当然data方法也可以用于更新数据,例如:
$Model = M('User'); $data['id'] = 8; $data['name'] = '流年'; $data['email'] = 'thinkphp@qq.com'; $Model->data($data)->save();
当然我们也可以直接这样用:
$Model = M('User'); $data['id'] = 8; $data['name'] = '流年'; $data['email'] = 'thinkphp@qq.com'; $Model->save($data);
同样,此时data参数只能传入数组。
在调用save方法更新数据的时候 会自动判断当前的数据对象里面是否有主键值存在,如果有的话会自动作为更新条件。也就是说,下面的用法和上面等效:
$Model = M('User'); $data['name'] = '流年'; $data['email'] = 'thinkphp@qq.com'; $Model->data($data)->where('id=8')->save();
2.读操作
除了写操作外,data方法还可以用于读取当前的数据对象,例如:
$User = M('User'); $map['name'] = '流年'; $User->where($map)->find(); // 读取当前数据对象 $data = $User->data();
本文向大家介绍ThinkPHP CURD方法之field方法详解,包括了ThinkPHP CURD方法之field方法详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP CURD方法的field方法属于模型的连贯操作方法之一,主要目的是标识要返回或者操作的字段,可以用于查询和写入操作。 1、用于查询 在查询操作中field方法是使用最频繁的。 这里使用field方法指定了查询的结果集中
本文向大家介绍ThinkPHP CURD方法之order方法详解,包括了ThinkPHP CURD方法之order方法详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP CURD方法的order方法属于模型的连贯操作方法之一,该方法用于对操作的结果排序。 具体用法如下: 注意:连贯操作方法没有顺序,可以在select方法调用之前随便改变调用顺序。 支持对多个字段的排序,例如: 如果没有
本文向大家介绍ThinkPHP CURD方法之table方法详解,包括了ThinkPHP CURD方法之table方法详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP CURD方法的table方法也属于模型类的连贯操作方法之一,该方法主要用于指定操作的数据表。 具体用法如下: 一般情况下,操作模型的时候系统能够自动识别当前对应的数据表,所以,使用table方法的情况通常是为了: 1.
本文向大家介绍ThinkPHP CURD方法之page方法详解,包括了ThinkPHP CURD方法之page方法详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP CURD方法的page方法也是模型连贯操作方法之一,是完全为分页查询而诞生的一个人性化操作方法。 用法 我们在前面已经分析了关于limit方法用于分页查询的情况,而page方法则是更人性化的进行分页查询的方法,我们还是以文
本文向大家介绍ThinkPHP CURD方法之limit方法详解,包括了ThinkPHP CURD方法之limit方法详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP CURD方法的limit方法也是模型类的连贯操作方法之一,主要用于指定查询和操作的数量,特别在分页查询的时候使用较多。并且ThinkPHP的limit方法可以兼容所有的数据库驱动类。 其具体用法如下: 1.限制结果数量
本文向大家介绍ThinkPHP CURD方法之where方法详解,包括了ThinkPHP CURD方法之where方法详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP CURD操作的查询方法中最常用但也是最复杂的就是where方法。where方法也属于模型类的连贯操作方法之一,主要用于查询和操作条件的设置。 where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP