文档章节

Thinkphp5.0---更新数据

ITCHN
 ITCHN
发布于 2016/11/24 16:09
字数 462
阅读 57
收藏 0
点赞 0
评论 0

模型的新增和更新方法都是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
ThinkPHP V5.0 RC2 版本发布(官方消息)

ThinkPHP V5.0——为API开发而设计的高性能框架 V5.0版本由七牛云独家赞助发布 ThinkPHP5.0版本是一个颠覆和重构版本,基于PHP5.4设计(支持PHP7),采用全新的架构思想,引入了很多的PHP新特...

流年
2016/03/11
3.3K
38
yihank/壹凯巴cms

1kbcms内容管理系统 1kbcms是一款基于thinkphp5.0开发,为小型企业建站,灵活组装开发的管理系统。 1kbcms完全开放源代码,具有良好的开放性、高可扩展性、安全性和透明性,您可以进行二次开...

yihank
2017/06/12
0
0
jaylin/minithink

由于个人原因,此项目本人已不再提供升级维护,已转交给jiruitech,本仓库项目代码仅供学习交流,谨慎使用开发项目!!! https://gitee.com/jiruitech/minithink #minithink 开发手册:htt...

jaylin
2017/05/06
0
0
sentcms管理系统/sentcms

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

sentcms管理系统
2016/06/22
0
0
thinkphp5.0生命周期

1、入口文件 用户发起的请求都会经过应用的入口文件,通常是 文件。当然,你也可以更改或者增加新的入口文件。 通常入口文件的代码都比较简单,一个普通的入口文件代码如下: 一般入口文件已...

创维_yang
04/13
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

SpringBoot | 第十章:Swagger2的集成和使用

前言 前一章节介绍了mybatisPlus的集成和简单使用,本章节开始接着上一章节的用户表,进行Swagger2的集成。现在都奉行前后端分离开发和微服务大行其道,分微服务及前后端分离后,前后端开发的...

oKong
今天
9
0
Python 最小二乘法 拟合 二次曲线

Python 二次拟合 随机生成数据,并且加上噪声干扰 构造需要拟合的函数形式,使用最小二乘法进行拟合 输出拟合后的参数 将拟合后的函数与原始数据绘图后进行对比 import numpy as npimport...

阿豪boy
今天
4
0
云拿 无人便利店

附近(上海市-航南路)开了家无人便利店.特意进去体验了一下.下面把自己看到的跟大家分享下. 经得现场工作人员同意后拍了几张照片.从外面看是这样.店门口的指导里强调:不要一次扫码多个人进入....

周翔
昨天
1
0
Java设计模式学习之工厂模式

在Java(或者叫做面向对象语言)的世界中,工厂模式被广泛应用于项目中,也许你并没有听说过,不过也许你已经在使用了。 简单来说,工厂模式的出现源于增加程序序的可扩展性,降低耦合度。之...

路小磊
昨天
175
1
npm profile 新功能介绍

转载地址 npm profile 新功能介绍 npm新版本新推来一个功能,npm profile,这个可以更改自己简介信息的命令,以后可以不用去登录网站来修改自己的简介了 具体的这个功能的支持大概是在6这个版...

durban
昨天
1
0
Serial2Ethernet Bi-redirection

Serial Tool Serial Tool is a utility for developing serial communications, custom protocols or device testing. You can set up bytes to send accordingly to your protocol and save......

zungyiu
昨天
1
0
python里求解物理学上的双弹簧质能系统

物理的模型如下: 在这个系统里有两个物体,它们的质量分别是m1和m2,被两个弹簧连接在一起,伸缩系统为k1和k2,左端固定。假定没有外力时,两个弹簧的长度为L1和L2。 由于两物体有重力,那么...

wangxuwei
昨天
0
0
apolloxlua 介绍

##项目介绍 apolloxlua 目前支持javascript到lua的翻译。可以在openresty和luajit里使用。这个工具分为两种模式, 一种是web模式,可以通过网页使用。另外一种是tool模式, 通常作为大规模翻...

钟元OSS
昨天
2
0
Mybatis入门

简介: 定义:Mybatis是一个支持普通SQL查询、存储过程和高级映射的持久层框架。 途径:MyBatis通过XML文件或者注解的形式配置映射,实现数据库查询。 特性:动态SQL语句。 文件结构:Mybat...

霍淇滨
昨天
2
0
开发技术瓶颈期,如何突破

前言 读书、学习的那些事情,以前我也陆续叨叨了不少,但总觉得 “学习方法” 就是一个永远在路上的话题。个人的能力、经验积累与习惯方法不尽相同,而且一篇文章甚至一本书都很难将学习方法...

_小迷糊
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部