微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

更新数据

(1)创建模版:/App/Home/View/Form/edit.html

  <FORM method="post" action="__URL__/update">

    标题:<INPUT type="text" name="title" value="{$vo.title}"><br/>

    内容:<TEXTAREA name="content" rows="5" cols="45">{$vo.content}</TEXTAREA><br/>

    <INPUT type="hidden" name="id" value="{$vo.id}">

    <INPUT type="submit" value="提交">

  </FORM>

(2)创建控制器中定义方法:/App/Home/Controller/FormController.class.PHP

public function edit($id=0){

    $Form   =   M('Form');

    $this->vo   =   $Form->find($id);

    $this->display();

}

public function update(){

    $Form   =   D('Form');

    if($Form->create()) {

        $result =   $Form->save();

        if($result) {

            $this->success('操作成功!');

        }else{

            $this->error('写入错误!');

        }

    }else{

        $this->error($Form->getError());

    }

}

(3)访问:http://127.0.0.1/app/index.PHP/Home/Form/edit/id/1

说明:数据的更新操作在ThinkPHP使用save方法,可以看到,我们同样可以使用create方法创建表单提交的数据,而save方法则会自动把当前的数据对象更新到数据库,而更新的条件其实就是表的主键,这就是我们在编辑页面要把主键的值作为隐藏字段一起提交的原因。

如果更新操作不依赖表单的提交的话,就可以写成:

$Form = M("Form"); 

// 要修改的数据对象属性赋值

$data['id'] = 5;

$data['title'] = 'ThinkPHP';

$data['content'] = 'ThinkPHP3.1版本发布';

$Form->save($data); // 根据条件保存修改的数据

save方法自动识别数据对象中的主键字段,并作为更新条件。当然,你也可以显式的传入更新条件:

$Form = M("Form"); 

// 要修改的数据对象属性赋值

$data['title'] = 'ThinkPHP';

$data['content'] = 'ThinkPHP3.1版本发布';

$Form->where('id=5')->save($data); // 根据条件保存修改的数据

也可以改成对象方式来操作:

$Form = M("Form"); 

// 要修改的数据对象属性赋值

$Form->title = 'ThinkPHP';

$Form->content = 'ThinkPHP3.1版本发布';

$Form->where('id=5')->save(); // 根据条件保存修改的数据

数据对象赋值的方式,save方法无需传入数据,会自动识别。

save方法的返回值是影响的记录数,如果返回false则表示更新出错。

有些时候,我们只需要修改某个字段的值,就可以使用setField方法,而不需要每次都调用save方法

$Form = M("Form"); 

// 更改title值

$Form->where('id=5')->setField('title','ThinkPHP');

对于统计字段,系统还提供了更加方便的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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐