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

Laravel学习记录--Model

Laravel 自带 软删除功能 就利用全局作用域从数据库中提取「未删除」模型。编写自定义全局作用域可以提供一个方便、简单方法确保给定模型每个查询都受到一定约束。...//查询限制年龄大于200 } } 应用全局作用域 要将全局作用域分配给模型,需要重写给定模型 boot 方法并使用 addGlobalScope 方法: <?...Eloquent 还能使用闭包定义全局作用域,如此一,便就没必要定义一个单独类了: namespace App; use Illuminate\Database\Eloquent\Model...,并且电话id = 1; } 关联数据计数 如果你只想统计结果数并不需要加载数据,那么可以使用withCount方法,此方法会在你结果集模型添加一个{关联名_count}字段 查询每个用户号码数量...,可在同一次关联上多次计数 统计用户号码数量,和用户号码包含7数量 public function show(){ $res = Muser::withCount(['phone'

13.4K20

Laravel Eloquent 模型关联关系(下)

在前面两篇教程,学院君陆续给大家介绍了 Eloquent 模型类支持七种关联关系,通过底层提供关联方法,我们可以快速实现模型关联,并且进行关联查询。...: $user = User::findOrFail(1); $posts = $user->posts()->where('views', '>', 0)->get(); 这样,我们就可以过滤出该用户发布文章浏览数大于...统计关联模型 我们还可以通过 Eloquent 提供 withCount 方法在不加载关联模型情况下统计关联结果数量。...: 结语 好了,关于关联关系我们就介绍到这里,我们分了三篇篇幅介绍 Eloquent 模型管理关系,回顾一下,主要包含以下内容: 七种关联关系定义:一对一、一对多、多对多、远层一对多、一对一多态关联...希望你看完学院君这一系列教程可以了解并完全掌握 Eloquent 模型定义和使用,有什么问题,欢迎随时与我交流。

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

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

模型Eloquent ORM使用(二) 对于模型探索我们还将继续。上篇文章,只是简单地通过模型操作了一下数据库,并且学习了一下关联操作知识。...而我们在日常操作,其实最习惯使用数组那种形式操作,除开我们后面会讲直接从配置入手修改 PDO FETCH 属性之外,我们还可以用上面这个 map() 函数配合模型对象 attributesToArray...() 方法模型对象转换成数组格式。...在所有模型都要继承 laravel/framework/src/Illuminate/Database/Eloquent/Model.php 类,我们很快就能发现一个 query() 静态方法。...但是,这里划重点了,Eloquent\Builder 中有些方法是没有的,比如说 insert()、insertGetId() ,在模型使用 save() 就可以代替这两个方法操作。

2.8K20

PHP-web框架Laravel-Eloquent ORM(三)

四、查询构建器Laravel框架Eloquent ORM提供了方便查询构建器,用于构建复杂查询语句。下面是一些常用查询构建器方法。...where方法where方法用于添加条件查询,例如:$users = User::where('age', '>', 18)->get();上述代码,查询了年龄大于18岁所有用户。...总结通过上述文档和示例,我们可以看出Laravel框架Eloquent ORM提供了便捷对象关系映射功能,可以大大简化开发者数据库操作。...在使用Eloquent ORM进行开发时,需要注意以下几点:模型类名默认对应表名是模型类名复数形式,User模型对应表名是users,如果需要指定表名可以通过定义$table属性实现。...查询构建器提供了丰富方法构建复杂查询语句,可以根据具体需求进行使用

1.5K41

为什么 Laravel 这么优秀?

这篇文章使用 Demo 是最新版 Laravel 10.x 以及 PHP 8.2。...另一个强大之处在于可以通过 Eloquent 抽象「模型模型」之间关系;举个例子,在下面的定义我们描述了一个 Course 可以有多个 Student、一个 Teacher;以及一个 Student...可以高效使用 Eloquent ORM 实现各种查询;如上面的例子我们使用withCount 查询课程学生数量、用 with 加载课程对应教师;还可以指定生成 SQL 查询只包含某几个字段...我们还使用Laravel Resource 格式化最终输出格式,这样做原因是很多情况下我们不希望直接将数据库字段暴露出去,你甚至还能在 Laravel Resource 按不同角色显示不同字段...; CacheServiceProvider 会向容器中注册 Cache 对象,后续在使用 Cache::get 时就使用是这里注册 Cache 对象,在注册阶段不应该向容器获取值,因为此时服务可能还没有

14910

Laravel 模型关联基础教程详解

Laravel 定义模型关联是每个 Laravel 开发者可能已经做过不止一次事情。但是在试图实现关联时可能会遇到各种问题。因为 Laravel 有各种各样关联,你应该选择哪一个?...让我们看看如何在代码定义这种关联。 <?...在 Passport 模型,我们需要定义逆向关联。我们要让 Passport 模型知道它属于 User 模型。我们可以使用 belongsTo 方法实现这一点。 <?...此属性表示中间表,可以像任何其他模型一样使用。 举个例子,假设连接表有 created_at 字段,我们就可以使用 pivot 获取 created_at 字段。 <?...php $user- passport()- where('active', 1)- orderBy('expiration_date'); 检查关联是否存在 有时候你希望检查模型是否有添加某些关联

5.5K31

Laravel代码简洁之道和性能优化

经过一番调研之后发现了一个堪称神器扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...你可以在 Eloquent 模型使用 UPSERT 和 INSERT IGNORE 查询。...->upsert(...); 在 Eloquent ,所有版本 LumenHasUpsertQueries都需要该特性。...当然了还是有一些注意点和坑,下面分享一下 注意问题 要根据需求添加唯一索引 根据官方文档说明,我们model必须添加这行代码,才能以Eloquent方式用 use \Staudenmeir\...LaravelUpsert\Eloquent\HasUpsertQueries; 因为我们数据库时间是int类型,不是laravel默认时间格式,并且我们插入时间和更新时间也不是laravel默认字段

5.7K20

3分钟短文:Laravel slug,让你url地址更“好记”

而友好url地址更是能让人一目了然,增加用户好感。同时对于爬虫也是好示例,搜索引擎可以友好地展开工作了。 [img] 本文就来讲讲,如何在laravel构造友好url路由。 啥是slug?...使用 composer 安装: composer require cviebrock/eloquent-sluggable:^4.3 模型引入 Slug 功能 引入 eloquent-sluggable...当然了,如果没有使用路由参数绑定,eloquent-sluggable类库也为我们提供了友好trait,在模型文件内直接引入就好了: use Cviebrock\EloquentSluggable\Sluggable...findBySlugOrFail('laravel-hacking-and-coffee'); 归根结底,就是使用slug字段记录查询字符串,而slug字段在对应关系定义为 source => ‘name...数据量大了之后,这种等于WHERE子句性能必然不如ID字段主键索引来快。所以在数据库层面也同样需要优化。

3.5K11

laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析

分享给大家供大家参考,具体如下: 1、连接数据库 laravel连接数据库配置文件位于config/database.php,在其中connection字段包含laravel所支持数据库配置信息...Laravel内置Eloquent ORM提供了一种便捷方式帮助你组织数据库数据,每张数据表都对应一个与该表进行交互模型(Model),通过Model类,你可以对数据表进行查询、插入、更新、删除等操作...Eloquent ORM本质上是查询构建器,因此上面查询构建器所使用方法Eloquent都可以使用。...在使用create批量添加时,需要在模板通过fillable指定可以赋值字段,也可以guard指定不允许赋值字段。...通过上面的增删改查可以看出Eloquent可以使用查询构建器所有方法,除了增删改查外,还有where、聚合函数等。

13.3K51

3分钟短文:Laravel 模型查询数据库几个关键方法

引言 本期继续我们laravel学习,主要说一说laravel使用eloquent orm 模型 读取数据库条目的几个常用方法。 ?...因为设计原因,laravel支持链式操作 本质上方法返回值归属于不同类。所以在使用方法之前务必明确调用是哪个类那个方法,返回是什么类型数据。...eloquent门面为我们提供了很多好用链式操作方法, 在query builder筛选出合适条目后,返回一个eloquent collection,或者是一个 基类collection对象,可以直接使用集合方法操作数据集...所以我们推荐使用where语句进行数据库SQL操作,将合适结果集返回,这样精简了数据库负载, 再者,使用集合操作方法,对结果集进行进一步格式化,效率会高多。...比如常用数据统计,计数,求平均,求和等等等等,laravel调用起来方法也极为简单, 像下面这样: $countVips = Contact::where('vip', true)->count()

2K40

Laravel5.7 Eloquent ORM快速入门详解

此外,Eloquent 默认主键字段是自增整型数据,这意味着主键将会被自动转化为 int 类型,如果你想要使用非自增或非数字类型主键,必须在对应模型设置 incrementing 属性为 false...模型使用应用配置默认数据库连接,如果你想要为模型指定不同连接,可以通过 $connection 属性设置: <?...将 Eloquent 模型看作功能强大查询构建器,你可以使用流畅查询与其关联数据表。例如: <?...Laravel 自带软删除功能就使用了全局作用域从数据库拉出所有没有被删除模型。编写自定义全局作用域可以提供一种方便、简单方式确保给定模型每个查询都有特定条件约束。...,可以使用观察者对所有监听器分组到一个类,观察者类拥有反射你想要监听 Eloquent 事件对应方法名,每个方法接收模型作为唯一参数。

15K41

通过 Laravel Eloquent 模型实现简单增删改查操作

「ActiveRecord」是 ORM 一种实现模式,Eloquent 则是 Laravel「ActiveRecord」。...结合我们平时怎么创建使用模型,就可以更好理解这一理念了。...属性为模型类指定使用哪个连接: protected $connection = 'connection_name'; 查询数据 日常开发,大部分操作都是数据库查询数据,Eloquent 模型了为我们提供了很多方法帮助我们从数据库获取数据...实际上,Eloquent 模型类底层查询也是基于查询构建器实现,你可以在模型类上调用所有查询构建器 Where 查询方法,同样是以流接口模式构建方法链调用即可。...'] ); 有的时候我们可能需要批量更新模型对应数据表多条记录,这可以借助查询构建器实现: Post::where('views', '>', 0)->update(['views' => 100

7.9K20

Laravel Eloquent ORM 实现查询表中指定字段

使用Laravel ORMModel方法find, get, first方法获取数据对象时返回数据对象attributes属性数组里会包含数据表中所有的字段对应键值关系, 那么如何在ORM查询时只返回数据表中指定字段数据呢...很多时候,文档上没有写明用法需要我们去看源码探究,下面我们就来看一下这三个方法实现。...LaravelORM方法查询返回指定字段可通过如下三种方法实现 $data = ModelA::find($id, ['column1', 'column2']); $data = ModelA...'column2']); 在不同场景下三者中选符合需要使用即可。...以上这篇Laravel Eloquent ORM 实现查询表中指定字段就是小编分享给大家全部内容了,希望能给大家一个参考。

3K21

PHP-web框架Laravel-Eloquent ORM(一)

Laravel是一种基于PHP语言Web开发框架,其中Eloquent ORM功能为开发者提供了便捷对象关系映射(ORM)功能,可用于对数据库进行CRUD操作,同时也可以轻松地定义模型关联和查询。...下一、模型定义Eloquent ORM是Laravel框架一个基于Active Record模式ORM,通过模型与数据库表进行映射,实现数据增删改查操作。...在Laravel框架,每一个Eloquent ORM模型都对应着一个数据库表,通过继承Illuminate\Database\Eloquent\Model类定义模型。下面是一个示例:<?...在该模型,我们可以定义一些属性和方法,对数据表进行操作。...二、增删改查操作Laravel框架Eloquent ORM提供了一系列方便CRUD操作方法,如下:查询数据查询单个模型:$user = User::find($id);查询多个模型:$users

85451

laravel 模型Eloquent ORM 查询

up前面玩了 DB 查询,但是laravel开发基本不怎么使用db方式查询,应该有更强大 模型 Model 介绍 Laravel Eloquent ORM 提供了一个漂亮、简洁 ActiveRecord...每个数据库表都有一个对应模型」用来与该表交互。你可以通过模型查询数据表数据,以及在数据表插入新记录。 在开始之前,请确保在 config/database.php 配置数据库连接。...更多关于数据库配置信息,请查看 文档。 模型 就是把数据库表映射到模型类,用面向对象方式操作数据库,既然是面向对象自然就可以继承了可以方便复用。...laravel Model 使用先进 Eloquent ORM 但也有优缺点 优点是数据库操作变简单安全 缺点也明显数据库操作变缓慢笨重 Eloquent ORM 作为 laravel 亮点...使用是单数形式帕斯卡命名法 ,也就是首字母大写驼峰命名法 比如 up之前创建 test表 Model 命名就是 Test.php 但是呢, laravel 都能 用命令创建控制器生成表跟数据填充了

4.4K10

Laravel 使用 Scout 实现全文检索

Laravel 使用 Scout 实现全文检索 为何要采用全文检索 一个字块,可以秒级、毫秒级搜索出你搜索内容 最原先我们可以简单通过查询语句实现检索条件 比如: select * from table...where name like '%张三%'; 再或者搜索更多字段 select * from table where title like '%php&' or content like '%laravel...即使你在数据库添加了索引,还是不尽人意 因此需要一个更快、更快、更快数据查询,而 Laravel scout 就是专门为搜索解决难题 简介 Laravel Scout 为 Eloquent...通过使用模型观察者, Scout 会自动同步 Eloquent 记录搜索索引。 目前, Scout 自带一个 Algolia 驱动。...algolia 里,API Keys 目录 Application ID 就是 ALGOLIA_APP_ID, Admin API Key 就是 ALGOLIA_SECRET 配置模型索引 <?

4.2K10

Laravel 6.11 版本发布,优化了 Redis 多频道广播逻辑

Laravel 官方开发组本周发布了 Laravel 6.11.0 版本,新版本在 Eloquent 模型查询时新增 firstWhere 方法,优化了基于 Redis 多频道广播,以及一些现有版本问题修复...1、新增功能 Eloquent firstWhere() 方法 Eloquent 模型现在支持调用 firstWhere 方法,它功效和 where()->first() 一样,算是一个语法糖: /...'); 需要注意是这个方法仅仅在 Eloquent 模型查询可用,在数据库查询构建器不可用。...优化 Redis 多频道广播 在 Laravel 应用,一次发送事件到多个频道很常见,目前,我们做法是通过多个发布命令发送完全一样负载数据到指定 Redis 服务器,这将导致不必要数据传输,从而带来通信及性能损耗...所以,最新版本 Laravel 优化了这个问题,在 RedisBroadcaster 添加一段 Lua 脚本,允许一次广播数据到多个频道: 2、更新日志 接下来,我们大致看一下此次版本更新详细日志

1.4K10
领券