文档章节

Thinkphp5.0---更新数据

ITCHN
 ITCHN
发布于 2016/11/24 16:09
字数 462
阅读 378
收藏 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
石家庄
程序员
私信 提问
加载中
请先登录后再评论。
iOS 应用版本更新检查--Harpy

实现 app 版本检查功能。用户打开app之后,进行app的版本更新检查。如果检查到 appstore 上有当前qpp的新版本,则弹出对话框提醒用户下载。可以设置让用户选择下载或者强制用户下载。 [Code4...

匿名
2013/02/18
1.8K
0
开源数据访问组件--Smark.Data

Smark.Data是基于Ado.net实现的数据访问组件,提供基于强类型的查询表达式进行灵活的数据查询,统计,修改和删除等操作;采用基于条件驱动的操作模式,使数据操作更简单轻松;内部通过标准SQL...

泥水佬
2013/03/12
2.6K
0
数据中心生命周期管理--Foreman

Foreman是一个集成的数据中心生命周期管理工具,提供了服务开通,配置管理以及报告 功能,和Puppet Dahboard一样,Foreman也是一个Ruby on Rails程序.Foreman和 Dashboard不同的地方是在于,Fore...

匿名
2012/10/24
1.5W
0
Python数据分析工具包--Pandas

Python Data Analysis Library 或 pandas 是连接 SciPy 和 NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。Pandas 纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集...

匿名
2012/10/30
2.1W
2
轻量级数据存储服务--LLServer

LLServer是本人基于libevent和leveldb这两个开源软件,开发的轻量级数据存储服务器软件,借助libevent高效网络接口实现对leveldb的访问封装。 其支持http协议和memcached协议。也就是可以通过...

代震军
2012/11/06
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

如何在Vue中使用更复杂的插槽

Vue.js是一个易于使用的Web应用程序框架,可用于开发交互式前端应用程序。 在本文中,我将介绍命名插槽和作用域插槽。 命名插槽 有时我们的模板中会有多个插槽。为了区分每个插槽,我们必须给...

前端知否
03/28
0
0
AutoUpdater迁移到Github

一. 摘要   最近一两年在做跨平台的解决方案,使应用程序能支持Android, iOS, Windows, MacOs. Linux等操作系统,在Android, iOS上可以使用Google Play Store 和 Apple App Store 只带的自...

osc_r2ntyjuu
16分钟前
0
0
42. Photo Tourism:三维重建和图像渲染结合的典范

本文同步发表在我的微信公众号和知乎专栏“计算摄影学”,欢迎扫码关注, 一. 从PhotoSynth谢幕讲起 2017年2月6日,微软正式关闭了PhotoSynth的网站和相关服务。这可能是世界上第一个3D图像创...

WangHawk
05/28
0
0
VARCHART XGantt入门教程

甘特图(Xgantt)从1998年的第一个商用版本开始就致力于计划编制和项目管理方面控件的研究和开发,经过20多年的积累和沉淀,目前可为软件开发商和最终用户提供最顶级的计划编制和项目管理的控...

roffey
17分钟前
0
0
.NET 跨平台框架Avalonia UI: 填坑指北(一):熟悉UI操作

Avalonia 是一个跨平台的 .NET UI 框架,支持 Windows、Linux、Mac OSX... (以及Android IOS soon..) 本篇主要介绍Avalonia开发过程和Linux适配环节的几个疑难点.. avalonia for vs安装和.de...

osc_o9qsdhyv
17分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部