ORM 的全称是 Obejct Relational Mapping ,翻译过来就是 对象关系映射 ,再说得直白一点,就是用 面向对象 里的对象来 映射 数据库中的数据。...我们在关系型数据库中,一行数据就可以看成是一个对象,整个表就可以看成是这个对象的列表。这就是非常简单地针对 ORM 的理解。 Java 中的 Hibernate 就是早期非常经典的 ORM 框架。...在它的里面是 belongsTo() 方法的源码。接着,通过 newRelatedInstance() 方法实例化一个关系实例,也就是我们指定的 DbSex 模型的对象。...gender() 方法获得返回的结果,也就是获取上面的 BelongsTo() 对象。...在这段代码中,就是先调用 BelongsTo 对象的 getResults() 方法,获得关联的真正的 DbSex 这个 Model 对象,然后通过回调函数中的 setRelation() 绑定到 laravel
准备 需求: 获取项目下的所有任务,且需要合并公共任务 逻辑关系: • 一个项目有很多任务• 一个项目有很多项目成员• 一个任务有一个执行人 (当任务类型为:1 的时候为公共事务)• 一个人有多个项目...($userTask 是一个 User 对象集合,$userTask->tasks 会不会再次查询数据了?而不是直接获取的原有属性?),疑问出现了,我们就来测试看看: ......返回的结果是修改了的.... 这就尴尬了,难道是对象集合中的非对象属性不能这样赋值?也不对呀,思来想去决定对对象本身做一个探索,直接在 map 中打印 $userTask : ?...既然 attributes 被修改了,那究竟为啥在输出的时候只有他本身的属性有变更但是关联属性没有呢?...,所以呀还是得追根溯源,并不是把时间都浪费在尝试上面,多看看源码,会有想不到的收获,哈哈。
Active Record 是一种数据访问设计模式,它可以帮助你实现数据对象Object到关系数据库的映射。...应用Active Record时,每一个类的实例对象唯一对应一个数据库表的一行(一对一关系)。...1:N hasMany(XXX:class) 反之:belongsTo(XXX:class) ? ? 3.1 面向对象方式绑定一对多的关系 ?...public function habits() { return $this->belongsToMany(Habit::class); } 4.1 面向对象方式绑定多对多的关系 ?...获取每个国家论文总数: ? 五、多样化的一对多关系映射(多态关联) 面向对象多态:运行时加载机制 ? 更多:https://laravel-china.org/doc... 伪造数据: ? ?
引言 上一章我们介绍了比较简单的laravel模型关联关系中的一对一,介绍了关联操作方法。...belongsTo 关系 正好像对于一个词语,找到对应的反义词,或者说有一个图片,找到其镜像图片这样的。 有作用力,就有反作用力。一对一关系模型中,A有一个B,则反过来,B属于一个A。...这就是首先要介绍的 belongsTo 关系。...类中我们声明了 user() 方法用于关系用户模型, 所以此处链式调用 user 属性,返回的是一个 App\User 对象实例,其包含 User 模型的所有属性, 因此 email 属性也相应返回数据库内的字段值...写在最后 本文不失简单地介绍了belongsTo和hasMany两个关联关系,这在代码中仅次于hasOne关系, 使用的频次比较高的。而效率也就是根据外键多查询一次SQL的消耗而已。
下面是翻译自 Laravel-News 的一篇教程,总结了 Laravel 的对象关系映射框架(ORM)的几个小技巧。...模型属性: 时间戳, 附加属性(appends) 等 Eloquent模型有一些“参数”,会以该类的属性形式出现。...查询多个实体对象 find()方法想必大家都知道的吧?...BelongsTo 关联的默认模型对象 假设有个 Post(帖子) 对象属于 Author (作者)对象,在 Blade 模板中有下面的代码 {{ $post->author->name }} 但是如果作者被删除...那么就会导致报错,可能是“property of non-object(非对象属性)”。 当然你可以用下面的代码来必变这种错误: {{ $post->author->name ??
引言 laravel模型不但提供了可供数据库操作的增删改查,还附加了很多功能,最关键的要数模型的关联关系。本文说一说简单的一对一,和一对多关系。用代码说话,让大家更直观地理解。...使用的时候,先获取Contact条目,然后使用关联方法获取PhoneNumber对象, 代码是这样的: $contact = Contact::first();$contactPhone = $contact...->phoneNumber; 变量 $contactPhone 就是一个模型对象,可以直接访问其各个属性。...有同学会疑问, 这中间是靠什么办法关联获取的呢?都是数据库的条目,一定是走SQL查询了吧? 没错,laravel也的确是这样做的。...有了一对一关系,我们能不能从手机号码倒推,反向查询到通讯录条目呢?当然是可以的,这就是 一对一的逆函数 belongsTo。
引言 本期我们把目光投向laravel模型的关联关系上。...框架提供的关联关系,有很多种,其中对于一对一的关系, 有两个写法,一个是 belongsTo,一个是 hasOne,这俩到底啥区别,本文就来说一说。 ?...hasOne 方法,可以使用 user->phone 返回一个 Phone 模型对象,但是反过来不行, 你不能通过 Phone 获取 User,也就是 要达到这个目的,你需要在 Phone 模型中,相应地定义...因为关联关系的第二个,第三个参数,根本没有填写。所以这样对比是不直观的。 hasOne 和 belongsTo 最大的不同,是哪一方持有关系的外键。...写在最后 本文通过几个实例介绍了数据库模型的一对一,一对多,以及反向关联关系, 大家记住一点,belongsTo 是根据当前表存储的外键,去主表内查找记录,而且是返回一个模型对象,或者null。
上篇文章我们主要讲了Eloquent Model关于基础的CRUD方法的实现,Eloquent Model中除了基础的CRUD外还有一个很重要的部分叫模型关联,它通过面向对象的方式优雅地把数据表之间的关联关系抽象到了...按照Laravel设定好的模式来写关联模型每个人都能写出高效和优雅的代码 (这点我认为适用于所有的Laravel特性)。...“如果模型的 $attributes属性里没有这个字段,那么会尝试获取模型关联的值”: abstract class Model implements ... { public function...$key` 则从这里取出$key对应的值 //否则就尝试去获取模型关联的值 if (array_key_exists($key, $this->attributes) |...,在获取关联模型时给关系应用约束的 addEagerConstraints方法是在具体的关联类中定义的,我们可以看下HasMany类的这个方法。
本文来自阮一峰老师的《ORM 实例教程》,如果你用来laravel类的框架,应该对orm有一定的熟悉了,本文是做个深入的理解学习。...一、概述 面向对象编程和关系型数据库,都是目前最流行的技术,但是它们的模型是不一样的。 面向对象编程把所有实体看成对象(object),关系型数据库则是采用实体之间的关系(relation)连接数据。...数据库的表(table) --> 类(class) 记录(record,行数据)--> 对象(object) 字段(field)--> 对象的属性(attribute) ?...5.2 Model 的描述 Model 里面可以详细描述数据库表的定义,并且定义自己的方法(完整代码看这里)。...ORM 将这四类操作,都变成了对象的方法。 6.1 查询 前面已经说过,find()方法用于根据主键,获取单条记录(完整代码看这里)或多条记录(完整代码看这里)。
说明:本文主要说明Laravel Eloquent的延迟预加载(Eager Loading),使用延迟预加载来减少MySQL查询次数。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...开发环境:Laravel5.1+MAMP+PHP7+MySQL5.5 先写个店铺列表页 1.先装上开发插件三件套(具体可参考:Laravel5.2之Seeder填充数据小技巧) 不管咋样,先装上开发插件三件套...artisan ide-helper:generate php artisan ide-helper:models php artisan test-factory-helper:generate 表的关系如图...: 然后写Seeder,可以参考Laravel5.2之Seeder填充数据小技巧: php artisan make:seeder MerchantTableSeeder php artisan make...预加载查询 (1)嵌套预加载 Eloquent在通过属性访问关联数据时是延迟加载的,就是只有该关联数据只有在通过属性访问它时才会被加载。在查找上层模型时可以通过预加载关联数据,避免N+1问题。
四、查询构建器Laravel框架中的Eloquent ORM提供了方便的查询构建器,用于构建复杂的查询语句。下面是一些常用的查询构建器方法。...总结通过上述文档和示例,我们可以看出Laravel框架中的Eloquent ORM提供了便捷的对象关系映射功能,可以大大简化开发者的数据库操作。...它支持多种关联关系,包括一对一、一对多和多对多等,并且提供了方便的查询构建器,用于构建复杂的查询语句。...在使用Eloquent ORM进行开发时,需要注意以下几点:模型类名默认对应的表名是模型类名的复数形式,如User模型对应的表名是users,如果需要指定表名可以通过定义$table属性来实现。...关联关系的定义需要在对应的模型类中定义,例如一对一关联需要在hasOne和belongsTo方法中定义,一对多关联需要在hasMany和belongsTo方法中定义,多对多关联需要在belongsToMany
今天我们说一说,在Laravel中,如何关联模型,以及制定返回列,以精简返回数据。 学习时间 假如有两个模型 User 和 Post,一个用户会发布多个post,也就是一对多的关联关系。...: public function user(){ return $this->belongsTo('User'); } 现在假如有一个查询,获取所有的帖子,并返回发布者的信息。...with语句 模型的with语句用于调用模型内声明的关联关系,其实它接收一个数组,可以在查询时关联多张表,同时支持一个闭包,用于对关联表的查询语句进行裁切。...关联关系 我们注意到,在关联关系的声明上,第一节仅使用了 belongTo,hasMany 这样的属性,其实还可以链式调用。这样对于所有使用 with 语句关联的模型查询,都会生效。...')); } 特殊性 在Laravel5.5及以上的版本,支持在使用with语句的使用,按照格式书写返回指定列。
,如果是单条记录获取关联关系,就需要两次查询;如果是多条记录获取关联关系,比如文章列表页获取作者信息,因为每篇文章的作者通过动态属性获取都有一次查询,所以对N条记录来说,需要N+1次查询才能返回需要的结果...,Eloquent提供了一些方法和这张表进行交互,如Stus关联了Mclass对象,在获取这些关联对象后,可以通过模型的pivot属性访问中间表数据 public function show(){...,都会被自动赋予 pivot 属性,它代表中间表的一个模型对象,能像其它的 Eloquent 模型一样使用。...:当前模型的主键 $relatedKey:关联模型类的主键,由$relate指定的模型而定义 $inverse若为true,则查询的是关联对象本身,若为false,查询的是关联对象与父模型的对应关系。...)的touches属性即可,支持添加多个关联关系 如: <?
所谓 “对象”,就是本文所说的 “模型(Model)”;对象关系映射,即为模型间关系。...每次使用模型间关系的时候都写全参数,不要省略 相应的,如果使用 belongsTo() 关系,应该这么写: 的是一个对象集合。 相应的 belongsTo() 的用法跟上面一对一关系一样: 的对象/数组展开了。...我们可以使用一个重要的特性,关系预载入:http://laravel-china.org/docs/eloquent#eager-loading 直接上代码: $users = User::with('
, 这意味着主键将会被自动转化为 int 类型, 如果你想要使用非自增或非数字类型主键, 必须在对应模型中设置 $incrementing 属性为 false , 如果主键不是整型, 还要设置 $keyType...comment = new App\Comment(['message' => 'A new comment.']); $post = App\Post::find(1); // 调用 comments 方法获取关联关系实例...', ], ]); // 更新从属关联关系 (belongsTo) $account = App\Account::find(10); // associate 方法会在子模型设置外键 $user...->account()->associate($account); $user->save(); // 移除关联 (belongsTo) // dissociate 方法会设置关联关系的外键为 null...例如, 你可能想要使用 Laravel 加密器对存储在数据库中的数据进行加密, 并且在 Eloquent 模型中访问时自动进行解密.
说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...开发环境:Laravel5.2 + MAMP + PHP7 + MySQL5.5 开发插件三件套 在先聊测试数据填充器seeder之前,先装上开发插件三件套,开发神器。先不管这能干些啥,装上再说。...,还需要一张存放两者关系的表: //多对多关系,中间表的命名laravel默认按照两张表字母排序来的,写成tag_post会找不到中间表 php artisan make:migration create_post_tag_table...,在控制器里输入方法时会自动补全auto complete字段属性的方法: 2、mpociot/laravel-test-factory-helper 输入指令php artisan test-factory-helper...Faker是一个好用的生成假数据的第三方库,而这个开发插件会自动帮你生成这些属性,不用自己写了。 <?
定义模型类和关联关系 在模型类 Image 中定义其与 Post 的一对多关联: 属性显示传入了上传文件的名称和二进制内容,而不是 Illuminate\Http\UploadedFile 对象的引用,因为 UploadedFile 对象不能被序列化,...我们还传入了该图片所属的 Post 模型实例,以便后续更新其 image_id 属性值。...(); // 获取图片二进制数据后通过 Base64 进行编码 // $content = base64_encode($image->getContent()); // 获取图片存储的临时路径(相对路径...ImageUploadProcessor 的 path 属性以便在处理任务类时使用。
你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 Laravel 神通广大,能知过去未来之事,而是因为 Eloquent 对此做了默认的约定。...$this->belongsTo(User::class); } 同样,采用关联关系方法名作为动态属性即可访问该模型所属 User 模型实例: $profile = UserProfile::findOrFail...} 这样,我们就可以在文章模型实例上通过动态属性 user 来访问对应的用户信息: $post = Post::findOrFail(29); $author = $post->user; belongsTo...如果是单条记录获取关联关系,就需要两次查询;如果是多条记录获取关联关系,比如文章列表页获取作者信息,因为每篇文章的作者通过动态属性获取都有一次查询,所以对N条记录来说,需要「N+1」次查询才能返回需要的结果...relations 字段中有一个 pivot 属性,中间表字段就存放在这个属性对象上: 我们在遍历返回结果的时候可以在循环中通过 $post->pivot->tag_id 获取中间表字段值。
Eloquent Eloquent是laravel中的orm,采取的是active record的设计模式,里面的对象不仅包括领域逻辑,还包括了数据库操作,但是大家平时使用的时候可能没有探究eloquent...本文是orm系列的第二篇,也是Eloquent演化的第一篇,Eloquent系列会尝试着讲清楚Eloquent是如何一步一步演化到目前功能强大的版本的,但是毕竟个人能力有限,不可能分析的非常完善,总会有不懂的地方...= $this->eagerLoadRelations($models); } 获取has one关系,我们跟着看到代码,会调用到函数eagerLoadRelation,具体看代码: protected...note:以上分析的代码是:git co f6e2170 讲到这,我们列举下对象之间的关系 One-To-One User 和 Phone的1对1的关系, class User extends Model...Role的pivot属性。
模型类负责与数据库进行交互,这里的模型指的是数据表的模型,一个模型类对应一张数据表,数据表的字段会映射为模型类的属性,我们可以通过模型类提供的方法实现对应数据表记录的增删改查,这样一来,我们就将原来面向过程的数据库操作转化为面向对象风格的编程...我们把这种对象与数据表的映射称之为对象关系映射(Object Relational Mapping),简称 ORM。...Post.php 和 Album.php 中,它们继承了 Eloquent ORM 的模型类基类 Model,这样就可以使用 Eloquent 模型类支持的属性和方法。...模型实例归属于 Album 模型实例(通过 album_id 字段),而在 Album 类中通过 posts() 方法定义一个 Album 模型实例可能包含多个 Post 模型实例(一对多关联),这种关联关系与数据表记录的关联关系对应...注:本篇教程源码可以在 Github 获取:https://github.com/nonfu/master-laravel-code/tree/v0.9/practice/blog 小结 至此,我们就完成了
领取专属 10元无门槛券
手把手带您无忧上云