文档章节

Thinkphp5.0---更新数据

ITCHN
 ITCHN
发布于 2016/11/24 16:09
字数 462
阅读 89
收藏 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不同,它数据存储在内存之中,所以数据读取相对而言很快,用来做高并发非常不错....

梦梦阁
2018/06/06
0
0
多商户商城 WSTMart 升级到 ThinkPHP 5.0.3

THINKPHP最近是喜闻不断,先是在大好中秋给PHP 开发者最好的礼物,推出了5.0正式版,然后在国庆前推出5.0.1版本,继而在程序员节发布5.0.2,双11又推出了新的版本5.0.3 ... ... THINKPHP开源...

B2B2C商城系统
2016/11/17
2.9K
15
网站管理系统--SentCMS

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

墨龙
2015/04/14
8K
2
Thinkphp5.0模型---插入数据

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

ITCHN
2016/11/24
34
0

没有更多内容

加载失败,请刷新页面

加载更多

Nextjs+React非页面组件SSR渲染

@随风溜达的向日葵 Nextjs Nextjs是React生态中非常受欢迎的SSR(server side render——服务端渲染)框架,只需要几个步骤就可以搭建一个支持SSR的工程(_Nextjs_的快速搭建见Next.js入门)...

随风溜达的向日葵
49分钟前
0
0
如何在 Linux 系统查询机器最近重启时间

在你的 Linux 或类 UNIX 系统中,你是如何查询系统上次重新启动的日期和时间?怎样显示系统关机的日期和时间? last 命令不仅可以按照时间从近到远的顺序列出该会话的特定用户、终端和主机名...

来来来来来
今天
3
0
Redis协议是什么样的

前言 我们用过很多redis的客户端,有没有相过自己撸一个redis客户端? 其实很简单,基于socket,监听6379端口,解析数据就可以了。 redis协议 解析数据的过程主要依赖于redis的协议了。 我们...

春哥大魔王的博客
今天
6
0
乱入Linux界的我是如何学习的

欢迎来到建哥学Linux,咳!咳!咳!开个玩笑哈,我是一个IT男,IT界的入门选手,正在学习Linux。 在之前,一直想进军IT界,学习IT技术,但是苦于没有人指导,也不知道学什么,最开始我自己在...

linuxCool
今天
4
0
携程Apollo统一配置中心的搭建和使用(java)

一.Apollo配置中心介绍 1、What is Apollo 1.1 Apollo简介 Apollo(阿波罗)是携程框架部门研发的开源配置管理中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到...

morpheusWB
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部