ThinkPHP 更新数据的常用三大方法

crud在tp中重要性不言而喻,这里谈的是更新update在tp中的几个方法:

save()

用于向数据表更新数据,相当于 SQL 中的 UPDATE 行为。一般使用 save() 方法来更新数据库,并且也支持连贯操作的使用。

$Dao->where($condition)->save($data);
//或者:$Dao->where($condition)->data($data)->save();

这里的$data可以写成数组,防sql注入,也可以写成“id=$id”这种格式的字符串。如果需要更新的数据里面包含主键,那么 ThinkPHP 会自动把主键的值作为条件来更新。

此外,save還可以和create()方法結合使用:

$Dao->create($data);//创建数据对象,$data缺省默认表单提交post数据
$Dao->where($condition)->save();

setfield()

更新个别字段setfield()就比较好用了,返回值可以判断是否更新成功。

$Dao->where('uid = 2')->setField('name','csdn');

同时更新多个字段,弄成数组即可:

$Dao->where('uid = 28')->setField(array('username','csdn'),array('password','123456'));

setField() 方法的语法为:

setField(fields, value, condition='')
因此 两者区别就在于,不能以构造数据数组的方式传入 setField(),而需要将需要更新的字段与值分别传入 setField() 方法中。

setInc()和setDec()

能灵活运用就算是更新数据的小技巧,一般配合连贯操作where一起使用:

 $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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值