首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

laravel 模型Eloquent ORM 查询

up前面玩了 DB 查询,但是laravel开发基本不怎么使用db方式查询,应该有更强大的 模型 Model 介绍 LaravelEloquent ORM 提供一个漂亮、简洁的 ActiveRecord...模型 就是把数据库的表映射到模型类,用面向对象的方式来操作数据库,既然是面向对象自然就可以继承可以方便的复用。...laravel 的 Model 使用先进的 Eloquent ORM 但也有优缺点 优点是数据库的操作变的简单安全 缺点也明显数据库的操作变的缓慢笨重 Eloquent ORM 作为 laravel 中亮点...但是却报错了我们看到model生成的sql 莫名其妙拼接了一个 s 这里我百度一下 artisan 生成的model 若没有特别指定,laravel系统会默认自动对应名称为「Eloquent类名称的小写复数形态...// } 以后的模型不要直接由 Eloquent 派生,改为由 BaseModel 派生,就不用特殊指定表名,表名与模型名称直接一致,也不再驼峰呀什么的

4.4K10

Laravel Eloquent 模型关联关系(下)

在前面两篇教程中,学院君陆续给大家介绍 Eloquent 模型类支持的七种关联关系,通过底层提供的关联方法,我们可以快速实现模型间的关联,并且进行关联查询。...,这样做的好处是不需要指定关联模型与父模型的外键关联字段值,Eloquent 底层会自动判断并设置。...底层还提供为已有模型之间进行多对多关联的绑定和解除操作。...Eloquent 提供这种同步机制帮助我们更新子模型时触发父模型的更新时间 updated_at 字段值更新,要让该机制生效,需要在子模型中配置 $touches 属性: // 要触发更新的父级关联关系...(31); $comment->content = 'Laravel学院致力于提供优质Laravel中文学习资源'; $comment->save(); 再次查看评论模型及对应文章模型数据,可以看到文章模型的更新事件和评论模型的更新时间已经一致

19.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

laravel 模型Eloquent ORM 添加编辑删除

自动都变成了插入或者修改的时间,这就是使用模型的好处一大好处 删除 但是最后的这个 deleted_at 是空的,这个字段应该怎么用呢?...接下来 up 来学下模型的删除。 删除数据是一件很危险的行为,up 刚刚入行的时候不小心给生产环境的用户表删除了,当时全靠谷歌用的好给恢复不然我就跑路?,现实版删库跑路?。...当时我希望能有一个恢复删除的功能比如说回收站,laravel模型为我们提供很方便的软删除功能 要启用软删除首先数据表需要有 deleted_at 字段 之前玩迁移的时候简单的说了下创建迁移的时候调用...php namespace App\Models; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\...Laravel 的 数据库迁移 有创建这个字段的方法 现在,当你在模型实例上使用 delete 方法, 当前日期时间会写入 deleted_at 字段。

1.6K21

Laravel Eloquent 模型关联关系详解(上)

准备好数据表之后,接下来,我们来通过模型类建立 users 表和 user_profiles 表之间的关联,Eloquent 模型类底层提供相应的 API 方法帮助我们建立模型之间的关联。...你可能注意到了我们在定义关联关系时,仅仅指定模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认的约定。...为什么我们不需要指定 Laravel 就能完成这种关联呢,这是因为如果没有指定 $foreignKey,Eloquent 底层会通过如下方法去拼接: public function getForeignKey...遵循这种默认的约定,可以帮我们少写很多代码,减少很多额外的配置,所以如果不是迫不得已(比如从其他系统迁移过来),建议你在使用 Eloquent 的话,尽量遵循这些默认约定。...可以,Eloquent 为我们提供 with 方法,我们将需要查询的关联关系动态属性(关联方法名)传入该方法,并将其链接到 Eloquent 模型原有的查询中,就可以一次完成关联查询,加上模型自身查询

9.8K40

Laravel系列4.4】模型Eloquent ORM的使用(二)

模型Eloquent ORM的使用(二) 对于模型的探索我们还将继续。上篇文章中,只是简单地通过模型操作了一下数据库,并且学习一下关联操作的知识。...在所有模型都要继承的 laravel/framework/src/Illuminate/Database/Eloquent/Model.php 类中,我们很快就能发现一个 query() 静态方法。...不过这里需要注意的是,模型默认生成的 QueryBuilder 是 llaravel/framework/src/Illuminate/Database/Eloquent/Builder.php 对象,...但是,这里划重点了,Eloquent\Builder 中有些方法是没有的,比如说 insert()、insertGetId() ,在模型中,使用 save() 就可以代替这两个方法的操作。...相信有这些,后面的内容你也可以写出来了,期待大家的分享哦! 参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

2.8K20

Laravel系列4.3】模型Eloquent ORM的使用(一)

其实,Laravel 中的 Eloquent ORM 也是 Active Record 的实现,这也是现在 ORM 的主流。...; } 嗯,就这么简单,一个模型类就创建成功。...对于 Laravel 中标准的 Eloquent 模型类来说,每个表都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...在代码中,我们定义一个方法,名为 gender() ,然后在里面 return 一个 belongsTo() 方法。在这个方法中,第一个参数是指定要关联的模型,第二个参数是对应的字段。...下篇文章我们还将继续进行模型的学习以及整个模型的源码分析。 参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

8.8K20

深入理解 Laravel Eloquent(三)——模型间关系(关联)

在本篇文章中,我将跟大家一起学习 Eloquent 中最复杂也是最难理解的部分——模型间关系。...中文文档: http://laravel-china.org/docs/eloquent#relationships 下面我们开始一个一个地学习。...---- 这段代码除了展示一对一关系该如何使用之外,还传达三点信息,也是我对于大家使用 Eloquent 时候的建议: 1....其他关系 Eloquent 还提供 “远层一对多关联”、“多态关联” 和 “多态的多对多关联” 这另外三种用法,经过上面的学习,我们已经掌握 Eloquent 模型间关系的基本概念和使用方法,剩下的几种不常用的方法就留到我们用到的时候再自己探索吧...---- 至此,深入理解 Laravel Eloquent 系列文章到此结束。推荐继续了解 软删除 、转换成数组/JSON。 END

2.6K30

通过 Laravel Eloquent 模型实现批量赋值和软删除

在上一篇教程中,我们基于 Eloquent 模型实现对数据表记录的增删改查操作,今天我们在此基础上介绍两个 Eloquent 模型提供的高级功能 —— 批量赋值和软删除。...每次这么做得崩溃掉,到时候我们的控制器类里面可能会遍布这种设置代码,Laravel 号称的优雅就是打脸。所以这个时候,批量赋值就粉墨登场,批量赋值就是为我们解决这个问题的。...但是,细心的同学可能会发现,这里有一个安全隐患,如果用户发布的时候,包含了用户字段 user_id,并且设置的不是自己的用户 ID,而是其它用户的 ID,发布出来的文章就变成其他人发布的;又或者文章需要审核后才能发布...实现原理 Eloquent 模型类为我们提供「软删除」功能的支持。这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...本系列教程首发在Laravel学院(laravelacademy.org)

2.3K10

基于独立的 Laravel Eloquent 组件编写 ORM 模型

这里,我们选择使用更加简单的 Active Record 模式来实现 ORM 模型类,并且为了简化流程,我们直接基于 Laravel 框架的 Eloquent ORM 组件来编写,就不再重复造轮子。...下载 Eloquent ORM 相关扩展Eloquent ORM 作为 Laravel 框架自带的 ORM 实现,还可以在 Laravel 框架之外作为独立的 ORM 组件使用。...Eloquent 提供的模型事件功能,还可以下载 Laravel 提供的独立事件扩展包: composer require illuminate/events 上述扩展包下载完成后,就可以在博客项目根目录下的...模型类全局可用(为了编写 Eloquent 模型类,如果只是使用 Laravel 提供的数据库查询构建器功能,则不需要这些操作)。...app/model 目录下的 Post.php 和 Album.php 中,它们继承 Eloquent ORM 的模型类基类 Model,这样就可以使用 Eloquent 模型类支持的属性和方法。

1.9K10

Laravel Eloquent分表方法并使用模型关联的实现

众所周知 Laravel 是 PHP 开发项目最优美的框架之一,尤其是 Eloquent 对数据库的操作提供特别多的便利。...在实际开发中我们经常涉及到分库分表场景,那么怎样才能继续配合 Eloquent 优雅的使用 Model 模型呢,接下来给大家分享下我在实际开发中所遇到的问题。...2、表建好后开始创建 model 模型,按照惯例所有的模型都将写在 App\Models 下;首先我们先创建一个类名为 Model 的模型并继承 Illuminate\Database\Eloquent...newInstance($attributes, $exists); $model- setSuffix($this- suffix); return $model; } } 2、其他模型全都继承以上的...HasMany($instance- newQuery(), $this, $foreignKey, $localKey); } } 到此 model 发表查询及 model 关联就完成了,如果有其他更好的方式

2.2K42

Laravel Eloquent 模型类中使用作用域进行查询

问题引出 在通过 Eloquent 模型实现增删改查这篇教程中,我们已经学习了如何在 Eloquent 模型类中进行各种查询,但是这些查询大多需要手动调用查询构建器提供的各种方法来实现。...Eloquent 模型类提供的「Scope」功能就可以帮我们实现这种优化。「Scope」字面意义上翻译为「作用域」,有点不那么好理解,从功能上来说,把它看作预置的「过滤器」更合适。...「作用域」都是围绕模型类展开的,不管是全局作用域还是局部作用域,都是作用到某个模型类上。接下来,我们就来演示如何在 Eloquent 模型类上使用「作用域」进行查询。...这样,当我们通过 User 模型类进行查询的时候,就会自动应用全局作用域指定的查询条件,以 User::all() 为例,我们通过 Telescope 的 「Queries」 页面就能看到对应的 SQL...本系列教程首发在Laravel学院(laravelacademy.org)

2.4K20

Laravel 实现Eloquent模型分组查询并返回每个分组的数量 groupBy()

Laravel 5.5 Linux mint 18 PHPStorm 最近刚玩Laravel,手册源码还没来得及看完就跃跃欲试做了个小项目,其中有个需求是分组查询数据库中的一个字段并返回每个分组中的数量...- where('status', '< ', 1) - groupBy('status') - get(); 可惜总是爱折腾,不想着用点奇迹淫巧就对不起自己这手艺人,于是有:...as name',$sql) - groupBy('city') - get() - toArray(); 代码也不客气了,直接撂挑子...参考: Laravel Eloquent groupBy() AND also return count of each group 以上这篇Laravel 实现Eloquent模型分组查询并返回每个分组的数量...groupBy()就是小编分享给大家的全部内容,希望能给大家一个参考。

4.2K51

Laravel Eloquent 模型类zhon设置访问器和修改器

问题引出 前面两篇教程我们陆续为大家介绍模型类的基本增删改查操作,以及如何通过模型类进行批量赋值和软删除,今天我们继续为大家介绍模型类的高级特性 —— 访问器和修改器。...我们当然可以通过上述访问器和修改器完成这种操作,但是 Laravel 提供更加快捷的方法,对于一个在数据库中类型为 JSON 或 TEXT 的字段,我们可以在模型类中将字段对应属性类型转化设置为数组,...可以看到 settings 字段确实是以 JSON 格式保存到数据库,然后我们来看下数据读取,获取到模型实例后,打印 $user->settings 数据,可以看到已经是数组格式: ?...其它操作 Eloquent 模型类还为我们提供诸如日期修改器、其它属性转化等功能,但是没有高频应用场景,我一般就是用默认日期设置,至于除数组/JSON之外的其它属性转化可以通过良好的数据库设计和业务逻辑来实现...下一篇,我们将基于 Eloquent 模型类实现一些更高阶的功能 —— 查询作用域和模型事件,敬请期待。 本系列教程首发在Laravel学院(laravelacademy.org)

1.4K30

竟然有人质疑我还在用Laravel开发?别忘了PHP是最好的语言。(2)模型工厂类

个人认为Laravel是非常优雅的开发框架:优雅的设计模式、强大的功能实现、各种方便的扩展、持续的版本更新,更主要的是迄今为止我认为最优秀的技术开发社区。 我必须为Laravel打Call。...2020年9月8号,Laravel发布8.0版本。Laravel计划于2022年1月25日发布9.0版本。...组件,Tailwind 分页视图, 时间测试助手,artisan serve 的改进,事件监听器的改进,以及各种其他错误修复和可用性改进,对 Laravel 7.x 继续进行了改善。...模型类目录 由于压倒性的社区需求,现在默认的 Laravel 框架包含一个 app/Models 目录。我们希望你喜欢 Eloquent 的新家!...laravel/legacy-factories 扩展包,可以在 Laravel 8 中支持以前的模型工厂。

2.7K41

Laravel 6.12.0 版本发布,支持从扩展包加载模型工厂

Laravel 开发团队本周发布 6.12.0 版本,此次更新支持从扩展包加载模型工厂,通过 dump 函数测试 Session 数据,以及很多其他新特性。...下面我们一起来看下其中比较重要的一些新特性: 1、重要特性 1)从扩展包加载模型工厂 在 Laravel 6.12 中,你可以在扩展包中直接使用已经存在的模型工厂,而不需要重新创建它们,方法是在服务提供者中引入对应的包含模型工厂的文件...,然后就可以使用它们: // 在某个服务提供者中......$this->loadFactoriesFrom('source/database/factories'); // 还可以一次引入多个包含模型工厂的文件 $this->loadFactoriesFrom...TestResponse::dumpSession() 方法 新增 Str::isUuid() 方法 恢复对 PHPUnit 7 的支持 新增 Request::boolean() 方法 新增 Database\Eloquent

73610
领券