ThinkPHP 更新数据的常用三大方法
来源:互联网 发布:grpc python 编辑:程序博客网 时间:2024/05/17 23:26
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 0
- ThinkPHP 更新数据的常用三大方法
- Thinkphp的三大自动
- thinkPHP常用数据操作(三)连贯操作
- 恢复数据的三大方法
- ThinkPHP的一些常用方法
- ThinkPHP的orm和三大自动
- 类似thinkphp的三大自动
- thinkphp的model三大自动功能
- thinkphp更新数据库的五种方法
- 在使用ThinkPHP时候数据更新的时候,save()方法返回值为0的问题!!!!
- ThinkPHP三大自动
- ThinkPHP三大自动
- ThinkPHP三大自动
- THINKPHP三大自动
- thinkphp更新数据库数据
- Android——Listview更新数据的三种方法
- thinkphp配置连接数据库的常用方法
- thinkphp几个常用的字母方法
- 在Sublime和Hbulider上scss和less的使用,怎么自动化编译?
- Java容器
- 使用ASM操作Java字节码,实现AOP原理
- nginx+lua+kafka实现日志统一收集汇总
- (二)PHP语法的特点,变量,常量
- ThinkPHP 更新数据的常用三大方法
- RED5 - 流媒体协议基础知识
- PP红包app是真的吗?PP红包怎么激活? PP红包最新最全教程
- HDU3046 Pleasant sheep and big big wolf喜羊羊和灰太狼
- STM32时钟设置
- flask sqlalchemy 更改数据表中的数据报错InvalidRequestError: Object '<User at 0x423b550>' is already attached to
- ThreadLocal用法
- 链表C版
- scu 4438 Censor 字符串哈希+前缀和