文档章节

Thinkphp5.0---更新数据

ITCHN
 ITCHN
发布于 2016/11/24 16:09
字数 462
阅读 80
收藏 1

模型的新增和更新方法都是save 方法   并且根据主键进行更新

系统有一套默认的规则来识别当前的数据需要更新还是新增:
    (1).实例化模型后调用save方法表示新增;
    (2).查询数据后调用save方法表示更新;

        $user = User::get(1);
        $user->name = 'thinkphp';
        $user->email = 'thinkphp@qq.com';
        $user->save();

   (3) 调用模型的save方法后表示更新;

$user = new User;
// save方法第二个参数为更新条件
$user->save([ 'name' => 'thinkphp',  'email' => 'thinkphp@qq.com'],  ['id' => 1]);

@1 过滤非数据表字段的数据

$user = new User();
// 过滤post数组中的非数据表字段数据
$user->allowField(true)->save($_POST,['id' => 1]);

@2 指定某些字段写入

$user = new User();
// post数组中只有name和email字段会写入
$user->allowField(['name','email'])->save($_POST, ['id' => 1]);

批量更新数据
        可以使用saveAll方法批量更新数据:
$user = new User;
$list = [
            ['id'=>1, 'name'=>'thinkphp', 'email'=>'thinkphp@qq.com'],
            ['id'=>2, 'name'=>'onethink', 'email'=>'onethink@qq.com']
];
$user->saveAll($list);

                批量更新仅能根据主键值进行更新,其它情况请使用foreach 遍历更新。

如果你自己通过遍历批量更新数据,可以参考下面的方法:
$user = new User;
$list = [
                    ['id'=>1, 'name'=>'thinkphp', 'email'=>'thinkphp@qq.com'],
                    ['id'=>2, 'name'=>'onethink', 'email'=>'onethink@qq.com']
            ];
foreach($list as $data){
$user->data($data,true)->isUpdate(true)->save();
}

显式的指定当前调用save 方法是新增操作还是更新操作。

显式更新数据:

    $user = new User;
// 显式指定更新数据操作
$user->isUpdate(true)->save(['id' => 1, 'name' => 'thinkphp']);

显示新增数据:
$user = User::get(1);
$user->name = 'thinkphp';
// 显式指定当前操作为新增操作
$user->isUpdate(false)->save();

通过数据库类更新数据

$user = new User;
$user->where('id', 1)->update(['name' => 'thinkphp']);

如果传入update 的数据包含主键的话,可以无需使用where 方法。

$user = new User;
$user->update(['id' => 1, 'name' => 'thinkphp']);

 

© 著作权归作者所有

共有 人打赏支持
ITCHN
粉丝 1
博文 97
码字总数 43324
作品 0
石家庄
程序员
私信 提问
SentCMS v3.0 beta 网站管理系统全新重构

SentCMS介绍 SentCMS网站管理系统是南昌腾速科技有限公司倾力打造的一款简单易用的网站管理系统,SentCMS网站管理系统(下文简称SentCMS)继承了thinkphp5.0的优秀品质,秉承“大道至简”的设...

墨龙
2016/07/28
1K
3
ThinkPHP5.0中Redis的使用和封装

Redis是一种常用的非关系型数据库,主要用作数据缓存,数据保存形式为key-value,键值相互映射.它的数据存储跟MySQL不同,它数据存储在内存之中,所以数据读取相对而言很快,用来做高并发非常不错....

梦梦阁
06/06
0
0
网站管理系统--SentCMS

SentCMS介绍 SentCMS网站管理系统是南昌腾速科技有限公司倾力打造的一款简单易用的网站管理系统,SentCMS网站管理系统(下文简称SentCMS)继承了thinkphp5.0的优秀品质,秉承“大道至简”的设...

墨龙
2015/04/14
8K
2
ThinkPHP 5.0 RC2 发布——为API开发而设计

ThinkPHP5.0版本是一个颠覆和重构版本,基于PHP5.4设计(支持PHP7),采用全新的架构思想,引入了很多的PHP新特性,优化了核心,减少了依赖,实现了真正的惰性加载。 本次RC2版本改进如下: ...

金三胖
2016/03/11
1K
9
Thinkphp5.0模型---插入数据

一 添加一条数据 1.实例化模型对象后 单一赋值并保存: $user = new User; $user->name = 'thinkphp'; $user->email = 'thinkphp@qq.com'; $user->save(); 使用data 方法批量赋值: $user = ......

ITCHN
2016/11/24
34
0

没有更多内容

加载失败,请刷新页面

加载更多

day150-2018-11-17-英语流利阅读-待学习

歪果仁也疯狂:海外版抖音的征途 毛西 2018-11-17 1.今日导读 海外版抖音 TikTok 于 2017 年 5 月上线海外,至今覆盖全球 150 多个国家和地区,月活跃用户数已突破 5 亿。然而,“出海”的抖...

飞鱼说编程
今天
4
0
分布式学习最佳实践:从分布式系统的特征开始(附思维导图)

什么是分布式系统 回到顶部   分布式系统是由一组通过网络进行通信、为了完成共同的任务而协调工作的计算机节点组成的系统。分布式系统的出现是为了用廉价的、普通的机器完成单个计算机无法...

dragon_tech
今天
4
0
TOKEN设计

TOKEN设计 Api_Token 首先需要知道API是什么? API(Application Programming Interface)即应用程序接口。你可以认为 API 是一个软件组件或是一个 Web 服务与外界进行的交互的接口。而我们在...

DrChenXX
今天
3
0
浅谈“李氏代换”——从纪念金庸和斯坦李说起

李氏代换(LSP)简介 李氏代换是软件设计的一个原则,又名依赖倒转原则或依赖倒置原则,其衍生原则有接口分离原则等。该原则由Barbara Liskov于1988年提出。 该原则指出,程序中高级别的元素...

SamYjy
今天
33
0
JavaScript实现在线websocket WSS测试工具 -toolfk程序员工具网

本文要推荐的[ToolFk]是一款程序员经常使用的线上免费测试工具箱,ToolFk 特色是专注于程序员日常的开发工具,不用安装任何软件,只要把内容贴上按一个执行按钮,就能获取到想要的内容结果。T...

toolfk
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部