zoukankan      html  css  js  c++  java
  • laravel insert 、save、update、create区别(总结二)

    1、insert:插入数据时,需要维护 created_at 和 updated_at字段,

    2、save:无论插入或者更新,会自动维护,无需手动操作

    //插入:
    public function store(Request $request)
        {
            $flight = new Flight;
    
            $flight->name = $request->name;
    
            $flight->save();
        }
    
    //更新:
    
    $flight = App\Flight::find(1);
    
    $flight->name = 'New Flight Name';
    
    $flight->save();
    <strong>格式: Eloquent实例->save();</strong>

    插入操作例子中,HTTP 请求的参数 name 赋值给了 App\Flight 模型实例的 name 属性。调用 save 方法,一条记录就会插入数据库。created_at 和 updated_at 时间戳随着 save 方法的调用,会自动维护,无需手动操作

    save 方法也可用于模型更新。更新模型时,需要检索到它,然后设置模型属性,再调用 save 方法。同样地,updated_at 时间戳自动更新,无需手动操作

    3.update:更新操作,自动维护 updated_at字段

    也可一并更新查询到的多个模型。这个例子中,所有 active 和 destination 为 San Diego 的航班都被更新为延误:

    App\Flight::where('active', 1)
              ->where('destination', 'San Diego')
              ->update(['delayed' => 1]);

    update 方法接受一个字段为键、更新数据为值的数组

    4.create 自动维护 created_at 和 updated_at两个字段

    除了 save 和 saveMany 方法外,你还可以使用 create 方法。它接受一个属性数组,同时会创建模型并插入到数据库中。 还有, save 方法和 create 方法的不同之处在于, save 方法接受一个完整的 Eloquent 模型实例,而 create 则接受普通的 PHP 数组:

    $post = App\Post::find(1);
    
    $comment = $post->comments()->create([
        'message' => 'A new comment.',
    ]);

    {tip} 在使用 create 方法前,请务必确保查看过本文档的 批量赋值 章节。

    格式:create(【‘字段’=>值,组成的数组】);

    参考连接: https://learnku.com/docs/laravel/5.6/eloquent-relationships/1404#3d967c

    获取更多知识讲解微信搜索公众号:[ 码农编程进阶笔记]

    公众号直通车

     
  • 相关阅读:
    【2】通过Ajax方式上传文件(图片),使用FormData进行Ajax请求
    【1】mongoDB 的安装及启动
    第一篇博客
    Java Integer 进制转化的实现(附源码),对模与补码的理解
    筛法求素数(普通筛法与欧拉筛法) 这是个问题
    字典的拼接方法
    使用Selenium抓取百度指数一
    正则表达式30分钟入门教程
    微博抓取尝试
    __call__方法的最简要说明
  • 原文地址:https://www.cnblogs.com/lxwphp/p/15453360.html
Copyright © 2011-2022 走看看