更新数据

(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

相关文章

(1)创建数据表: CREATE TABLE IF NOT EXISTS `think_form` ...
组合查询的主体还是采用数组方式查询,只是加入了一些特殊的...
(1)创建模版:/App/Home/View/Form/edit.html   <FORM m...
自定义配置文件user.php: <?php return array(    \'se...
在一些成熟的CMS系统中,后台一般都包含一个配置中心(如织梦...
废话不多说先上图预览下,即本博客的分页; 这个分页类是在...