资讯专栏INFORMATION COLUMN

Laravel & Lumen之Eloquent ORM使用速查-基础部分

NervosNetwork / 2223人阅读

摘要:使用时,数据库查询构造器的方法对模型类也是也用的,使用上只是省略了表名部分。在模型中使用成员变量指定绑定的表名。

使用Eloquent ["eləkwənt] 时,数据库查询构造器的方法对模型类也是也用的,使用上只是省略了DB::table("表名")部分。

</>复制代码

  1. 在模型中使用protected成员变量$table指定绑定的表名。

</>复制代码

  1. Eloquent 假设每个表都有一个名为id的主键,可以通过$primaryKey成员变量覆盖该字段名称,另外,Eloquent假设主键字段是自增的整数,如果你想用非自增的主键或者非数字的主键的话,必须指定模型中的public属性$incrementingfalse

  2. 默认情况下,Eloquent期望表中存在created_atupdated_at两个字段,字段类型为timestamp,如果不希望这两个字段的话,设置$timestampsfalse

  3. </>复制代码

    1. 使用protected $connection = "connection-name"指定模型采用的数据库连接。

    2. 查询
    3. 基本查询操作
    4. 方法all用于返回模型表中所有的结果

    5. </>复制代码

      1. $flights = Flight::all();
      2. foreach ($flights as $flight) {
      3. echo $flight->name;
      4. }
    6. 也可以使用get方法为查询结果添加约束

    7. </>复制代码

      1. $flights = AppFlight::where("active", 1)
      2. ->orderBy("name", "desc")
      3. ->take(10)
      4. ->get();
    8. </>复制代码

      1. 可以看到,查询构造器的方法对模型类也是可以使用的

    9. 在eloquent ORM中,getall方法查询出多个结果集,它们的返回值是一个IlluminateDatabaseEloquentCollection对象,该对象提供了多种对结果集操作的方法

    10. </>复制代码

      1. public function find($key, $default = null);
      2. public function contains($key, $value = null);
      3. public function modelKeys();
      4. public function diff($items)
      5. ...
    11. 该对象的方法有很多,这里只列出一小部分,更多方法参考API文档 Collection 和使用说明文档。

    12. 对大量结果分段处理,同样是使用chunk方法

    13. </>复制代码

      1. Flight::chunk(200, function ($flights) {
      2. foreach ($flights as $flight) {
      3. //
      4. }
      5. });
    14. 查询单个结果
    15. 使用findfirst方法查询单个结果,返回的是单个的模型实例

    16. </>复制代码

      1. // 通过主键查询模型...
      2. $flight = AppFlight::find(1);
      3. // 使用约束...
      4. $flight = AppFlight::where("active", 1)->first();
    17. 使用find方法也可以返回多个结果,以Collection对象的形式返回,参数为多个主键

    18. </>复制代码

      1. $flights = AppFlight::find([1, 2, 3]);
    19. 如果查询不到结果的话,可以使用findOrFail或者firstOrFail方法,这两个方法在查询不到结果的时候会抛出IlluminateDatabaseEloquentModelNotFoundException异常

    20. </>复制代码

      1. $model = AppFlight::findOrFail(1);
      2. $model = AppFlight::where("legs", ">", 100)->firstOrFail();
    21. 如果没有捕获这个异常的话,laravel会自动返回给用户一个404的响应结果,因此如果希望找不到的时候返回404,是可以直接使用该方法返回的

    22. </>复制代码

      1. Route::get("/api/flights/{id}", function ($id) {
      2. return AppFlight::findOrFail($id);
      3. });
    23. 查询聚集函数结果
    24. 与查询构造器查询方法一样,可以使用聚集函数返回结果,常见的比如maxminavgsumcount

    25. </>复制代码

      1. $count = AppFlight::where("active", 1)->count();
      2. $max = AppFlight::where("active", 1)->max("price");
    26. 分页查询
    27. 分页查询可以直接使用paginate函数

    28. </>复制代码

      1. LengthAwarePaginator paginate(
      2. int $perPage = null,
      3. array $columns = array("*"),
      4. string $pageName = "page",
      5. int|null $page = null
      6. )
    29. 参数说明

    30. 参数类型说明
      perPageint每页显示数量
      columnsarray查询的列名
      pageNamestring页码参数名称
      pageint当前页码
    31. 返回值为 LengthAwarePaginator 对象。

    32. </>复制代码

      1. $limit = 20;
      2. $page = 1;
      3. return Enterprise::paginate($limit, ["*"], "page", $page);
    33. 插入
    34. 基本插入操作
    35. 插入新的数据只需要创建一个新的模型实例,然后设置模型属性,最后调用save方法即可

    36. </>复制代码

      1. $flight = new Flight;
      2. $flight->name = $request->name;
      3. $flight->save();
    37. </>复制代码

      1. 在调用save方法的时候,会自动为created_atupdated_at字段设置时间戳,不需要手动指定

    38. 批量赋值插入
    39. 使用create方法可以执行批量为模型的属性赋值的插入操作,该方法将会返回新插入的模型,在执行create方法之前,需要先在模型中指定fillableguarded属性,用于防止不合法的属性赋值(例如避免用户传入的is_admin属性被误录入数据表)。

    40. 指定$fillable属性的目的是该属性指定的字段可以通过create方法插入,其它的字段将被过滤掉,类似于白名单,而$guarded则相反,类似于黑名单。

    41. </>复制代码

      1. protected $fillable = ["name"];
      2. // OR
      3. protected $guarded = ["price"];
    42. 执行create操作就只有白名单或者黑名单之外的字段可以更新了

    43. </>复制代码

      1. $flight = AppFlight::create(["name" => "Flight 10"]);
    44. 除了create方法,还有两外两个方法可以使用firstOrNewfirstOrCreate

    45. firstOrCreate方法用来使用给定的列值对查询记录,如果查不到则插入新的。fristOrNewfirstOrCreate类似,不同在于如果不存在,它会返回一个新的模型对象,不过该模型是未经过持久化的,需要手动调用save方法持久化到数据库。

    46. </>复制代码

      1. // 使用属性检索flight,如果不存在则创建...
      2. $flight = AppFlight::firstOrCreate(["name" => "Flight 10"]);
      3. // 使用属性检索flight,如果不存在则创建一个模型实例...
      4. $flight = AppFlight::firstOrNew(["name" => "Flight 10"]);
    47. 更新
    48. 基本更新操作
    49. 方法save不仅可以要用来插入新的数据,也可以用来更新数据,只需先使用模型方法查询出要更新的数据,设置模型属性为新的值,然后再save就可以更新了,updated_at字段会自动更新。

    50. </>复制代码

      1. $flight = AppFlight::find(1);
      2. $flight->name = "New Flight Name";
      3. $flight->save();
    51. 也可使用update方法对多个结果进行更新

    52. </>复制代码

      1. AppFlight::where("active", 1)
      2. ->where("destination", "San Diego")
      3. ->update(["delayed" => 1]);
    53. 删除
    54. 基本删除操作
    55. 使用delete方法删除模型

    56. </>复制代码

      1. $flight = AppFlight::find(1);
      2. $flight->delete();
    57. 上述方法需要先查询出模型对象,然后再删除,也可以直接使用主键删除模型而不查询,使用destroy方法

    58. </>复制代码

      1. AppFlight::destroy(1);
      2. AppFlight::destroy([1, 2, 3]);
      3. AppFlight::destroy(1, 2, 3);
    59. 使用约束条件删除,返回删除的行数

    60. </>复制代码

      1. $deletedRows = AppFlight::where("active", 0)->delete();
    61. 软删除
    62. 软删除是在表中增加deleted_at字段,当删除记录的时候不会真实删除记录,而是设置该字段的时间戳,由Eloquent模型屏蔽已经设置该字段的数据。

    63. 要启用软删除,可以在模型中引用IlluminateDatabaseEloquentSoftDeletes这个Trait,并且在dates属性中增加deleted_at字段。

    64. </>复制代码

      1. 要判断一个模型是否被软删除了的话,可以使用trashed方法

      2. </>复制代码

        1. if ($flight->trashed()) {
        2. //
        3. }
      3. 查询软删除的模型
      4. 包含软删除的模型
      5. 如果模型被软删除了,普通查询是不会查询到该结果的,可以使用withTrashed方法强制返回软删除的结果

      6. </>复制代码

        1. $flights = AppFlight::withTrashed()
        2. ->where("account_id", 1)
        3. ->get();
        4. // 关联操作中也可以使用
        5. $flight->history()->withTrashed()->get();
      7. 只查询软删除的模型
      8. </>复制代码

        1. $flights = AppFlight::onlyTrashed()
        2. ->where("airline_id", 1)
        3. ->get();
      9. 还原软删除的模型
      10. 查询到软删除的模型实例之后,调用restore方法还原

      11. </>复制代码

        1. $flight->restore();
      12. 也可以在查询中使用

      13. </>复制代码

        1. AppFlight::withTrashed()
        2. ->where("airline_id", 1)
        3. ->restore();
        4. // 关联操作中也可以使用
        5. $flight->history()->restore();
      14. 强制删除(持久化删除)
      15. </>复制代码

        1. // Force deleting a single model instance...
        2. $flight->forceDelete();
        3. // Force deleting all related models...
        4. $flight->history()->forceDelete();
      16. 上述操作后,数据会被真实删除。


      17. 参考:

      18. Eloquent: Getting Started

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/21724.html

相关文章

  • Laravel &amp; LumenEloquent ORM使用速查-高级部分

    摘要:使用全局作用域功能可以为模型的所有操作增加约束。提供了一些方法可以方便的来实现数据类型之间的转换。要定义一个,需要在模型中创建一个名称为的方法,其中的是驼峰命名法的字段名。 查询作用域 全局作用域 全局作用域允许你对给定模型的所有查询添加约束。使用全局作用域功能可以为模型的所有操作增加约束。 软删除功能实际上就是利用了全局作用域功能 实现一个全局作用域功能只需要定义一个实现Illumi...

    BigNerdCoding 评论0 收藏0
  • Laravel &amp; LumenEloquent ORM使用速查-进阶部分

    摘要:关联关系查询在中,所有的关系都是使用函数定义的,可以在不执行关联查询的情况下获取关联的实例。 关联关系 One To One 假设User模型关联了Phone模型,要定义这样一个关联,需要在User模型中定义一个phone方法,该方法返回一个hasOne方法定义的关联

    Chaz 评论0 收藏0
  • Laravel &amp; Lumen 数据库操作速查

    摘要:在中执行数据库操作有两种方式,一种是使用外观对象的静态方法直接执行查询,另外一种是使用类的静态方法实际上也是的实现,使用静态访问方式访问的方法,内部采用了魔术方法代理了对成员方法的访问。在闭包函数中,如果返回,则会停止后续的处理。 在Laravel中执行数据库操作有两种方式,一种是使用DB外观对象的静态方法直接执行sql查询,另外一种是使用Model类的静态方法(实际上也是Facade...

    用户83 评论0 收藏0
  • Lumen 初体验(二)

    摘要:的现状目前是版本,是基于开发。入口文件启动文件和配置文件框架的入口文件是。在路由中指定控制器类必须写全命名空间,不然会提示找不到类。目前支持四种数据库系统以及。使用时发生错误,因为在文件中,的默认驱动是。 最近使用 Lumen 做了 2 个业余项目,特此记录和分享一下。 Lumen 的介绍 在使用一项新的技术时,了解其应用场景是首要的事情。 Lumen 的口号:为速度而生的 La...

    Cheriselalala 评论0 收藏0
  • 使用 Laravel 框架开发是什么样的体验

    摘要:但也因为应有尽有使得框架的性能比其他高性能框架低了些,为此给了几个解决方案路由缓存经有关部门研究,路由缓存可有效加快访问速度以上。有朋友说框架最重要的东西是路由,我倒认为最重要的是框架中异于其他框架且能解决痛点的东西,如的。 showImg(https://segmentfault.com/img/remote/1460000006767764); 在程序界的远古时期,大神们手持键盘敲...

    Miracle_lihb 评论0 收藏0

发表评论

0条评论

NervosNetwork

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<