ThinkPHP的数据更新操作包括更新数据和更新字段方法。 ## 更新数据 更新数据使用`save`方法,例如: ~~~ $User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->where('id=5')->save($data); // 根据条件更新记录 ~~~ 也可以改成对象方式来操作: ~~~ $User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $User->name = 'ThinkPHP'; $User->email = 'ThinkPHP@gmail.com'; $User->where('id=5')->save(); // 根据条件更新记录 ~~~ 数据对象赋值的方式,save方法无需传入数据,会自动识别。 > 注意:save方法的返回值是**影响的记录数**,如果返回false则表示更新出错,因此一定要用恒等来判断是否更新失败。 为了保证数据库的安全,避免出错更新整个数据表,如果没有任何更新条件,数据对象本身也不包含主键字段的话,save方法不会更新任何数据库的记录。 因此下面的代码不会更改数据库的任何记录 ~~~ $User->save($data); ~~~ 除非使用下面的方式: ~~~ $User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['id'] = 5; $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->save($data); // 根据条件保存修改的数据 ~~~ 如果id是数据表的主键的话,系统自动会把主键的值作为更新条件来更新其他字段的值。 数据更新方法支持的连贯操作方法有: | 连贯操作 | 作用 | 支持的参数类型 | |-----|-----|-----| | where | 用于查询或者更新条件的定义 | 字符串、数组和对象 | | table | 用于定义要操作的数据表名称 | 字符串和数组 | | alias | 用于给当前数据表定义别名 | 字符串 | | field | 用于定义允许更新的字段 | 字符串和数组 | | order | 用于对数据排序 | 字符串和数组 | | lock | 用于数据库的锁机制 | 布尔值 | | relation | 用于关联更新(需要关联模型支持) | 字符串 | | scope | 用于命名范围 | 字符串、数组 | | bind | 用于数据绑定操作 | 数组 | | comment | 用于SQL注释 | 字符串 | | fetchSql | 不执行SQL而只是返回SQL | 布尔值 | ##### 字段和数据过滤 和add方法一样,save方法支持使用`field`方法过滤字段和`filter`方法过滤数据,例如: ~~~ $User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'test'; $data['email'] = '<b>test@gmail.com</b>'; $User->where('id=5')->field('email')->filter('strip_tags')->save($data); // 根据条件保存修改的数据 ~~~ 当使用field('email')的时候,只允许更新email字段的值(采用strip_tags方法过滤),name字段的值将不会被修改。 还有一种方法是通过create或者data方法创建要更新的数据对象,然后进行保存操作,这样save方法的参数可以不需要传入。 ~~~ $User = M("User"); // 实例化User对象 // 要修改的数据对象属性赋值 $data['name'] = 'ThinkPHP'; $data['email'] = 'ThinkPHP@gmail.com'; $User->where('id=5')->data($data)->save(); // 根据条件保存修改的数据 ~~~ 使用create方法的例子: ~~~ $User = M("User"); // 实例化User对象 // 根据表单提交的POST数据创建数据对象 $User->create(); $User->save(); // 根据条件保存修改的数据 ~~~ ## 更新字段 如果只是更新个别字段的值,可以使用`setField`方法。 使用示例: ~~~ $User = M("User"); // 实例化User对象 // 更改用户的name值 $User-> where('id=5')->setField('name','ThinkPHP'); ~~~ setField方法支持同时更新多个字段,只需要传入数组即可,例如: ~~~ $User = M("User"); // 实例化User对象 // 更改用户的name和email的值 $data = array('name'=>'ThinkPHP','email'=>'ThinkPHP@gmail.com'); $User-> where('id=5')->setField($data); ~~~ 而对于统计字段(通常指的是数字类型)的更新,系统还提供了`setInc`和`setDec`方法。 ~~~ $User = M("User"); // 实例化User对象 $User->where('id=5')->setInc('score',3); // 用户的积分加3 $User->where('id=5')->setInc('score'); // 用户的积分加1 $User->where('id=5')->setDec('score',5); // 用户的积分减5 $User->where('id=5')->setDec('score'); // 用户的积分减1 ~~~ 3.2.3版本开始,setInc和setDec方法支持延迟更新,用法如下: ~~~ $Article = M("Article"); // 实例化Article对象 $Article->where('id=5')->setInc('view',1); // 文章阅读数加1 $Article->where('id=5')->setInc('view',1,60); // 文章阅读数加1,并且延迟60秒更新(写入) ~~~