美文网首页
二十一.数据的更新

二十一.数据的更新

作者: 张金宇 | 来源:发表于2016-10-06 08:44 被阅读0次

    方法一.

    $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方法无需传入数据,会自动识别。

    字段和数据过滤

    和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方法的参数可以不需要传入。

    使用data方法的例子:

    $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秒更新(写入)

    相关文章

      网友评论

          本文标题:二十一.数据的更新

          本文链接:https://www.haomeiwen.com/subject/tyceyttx.html