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

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

ORM 的全称是 Obejct Relational Mapping ,翻译过来就是 对象关系映射 ,再说得直白一点,就是用 面向对象 里的对象来 映射 数据库中的数据。...我们在关系型数据库中,一行数据就可以看成是一个对象,整个表就可以看成是这个对象的列表。这就是非常简单地针对 ORM 的理解。 Java 中的 Hibernate 就是早期非常经典的 ORM 框架。...在它的里面是 belongsTo() 方法的源码。接着,通过 newRelatedInstance() 方法实例化一个关系实例,也就是我们指定的 DbSex 模型的对象。...gender() 方法获得返回的结果,也就是获取上面的 BelongsTo() 对象。...在这段代码中,就是先调用 BelongsTo 对象的 getResults() 方法,获得关联的真正的 DbSex 这个 Model 对象,然后通过回调函数中的 setRelation() 绑定到 laravel

8.9K20

Laravel 模型操作中一次奇妙踩坑经历

准备 需求: 获取项目下的所有任务,且需要合并公共任务 逻辑关系: • 一个项目有很多任务• 一个项目有很多项目成员• 一个任务有一个执行人 (当任务类型为:1 的时候为公共事务)• 一个人有多个项目...($userTask 是一个 User 对象集合,$userTask->tasks 会不会再次查询数据了?而不是直接获取的原有属性?),疑问出现了,我们就来测试看看: ......返回的结果是修改了的.... 这就尴尬了,难道是对象集合中的非对象属性不能这样赋值?也不对呀,思来想去决定对对象本身做一个探索,直接在 map 中打印 $userTask : ?...既然 attributes 被修改了,那究竟为啥在输出的时候只有他本身的属性有变更但是关联属性没有呢?...,所以呀还是得追根溯源,并不是把时间都浪费在尝试上面,多看看源码,会有想不到的收获,哈哈。

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

    3分钟短文:说说Laravel模型中还算常用的2个“关系”

    引言 上一章我们介绍了比较简单的laravel模型关联关系中的一对一,介绍了关联操作方法。...belongsTo 关系 正好像对于一个词语,找到对应的反义词,或者说有一个图片,找到其镜像图片这样的。 有作用力,就有反作用力。一对一关系模型中,A有一个B,则反过来,B属于一个A。...这就是首先要介绍的 belongsTo 关系。...类中我们声明了 user() 方法用于关系用户模型, 所以此处链式调用 user 属性,返回的是一个 App\User 对象实例,其包含 User 模型的所有属性, 因此 email 属性也相应返回数据库内的字段值...写在最后 本文不失简单地介绍了belongsTo和hasMany两个关联关系,这在代码中仅次于hasOne关系, 使用的频次比较高的。而效率也就是根据外键多查询一次SQL的消耗而已。

    2.1K31

    3分钟短文:Laravel模型一对一一对多关系真的乱吗?

    引言 laravel模型不但提供了可供数据库操作的增删改查,还附加了很多功能,最关键的要数模型的关联关系。本文说一说简单的一对一,和一对多关系。用代码说话,让大家更直观地理解。...使用的时候,先获取Contact条目,然后使用关联方法获取PhoneNumber对象, 代码是这样的: $contact = Contact::first();$contactPhone = $contact...->phoneNumber; 变量 $contactPhone 就是一个模型对象,可以直接访问其各个属性。...有同学会疑问, 这中间是靠什么办法关联获取的呢?都是数据库的条目,一定是走SQL查询了吧? 没错,laravel也的确是这样做的。...有了一对一关系,我们能不能从手机号码倒推,反向查询到通讯录条目呢?当然是可以的,这就是 一对一的逆函数 belongsTo。

    2.1K30

    3分钟短文:Laravel 模型一对一关联关系这俩啥区别

    引言 本期我们把目光投向laravel模型的关联关系上。...框架提供的关联关系,有很多种,其中对于一对一的关系, 有两个写法,一个是 belongsTo,一个是 hasOne,这俩到底啥区别,本文就来说一说。 ?...hasOne 方法,可以使用 user->phone 返回一个 Phone 模型对象,但是反过来不行, 你不能通过 Phone 获取 User,也就是 要达到这个目的,你需要在 Phone 模型中,相应地定义...因为关联关系的第二个,第三个参数,根本没有填写。所以这样对比是不直观的。 hasOne 和 belongsTo 最大的不同,是哪一方持有关系的外键。...写在最后 本文通过几个实例介绍了数据库模型的一对一,一对多,以及反向关联关系, 大家记住一点,belongsTo 是根据当前表存储的外键,去主表内查找记录,而且是返回一个模型对象,或者null。

    2.7K20

    Laravel源码分析之模型关联

    上篇文章我们主要讲了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类的这个方法。

    9.6K10

    ORM 实例教程

    本文来自阮一峰老师的《ORM 实例教程》,如果你用来laravel类的框架,应该对orm有一定的熟悉了,本文是做个深入的理解学习。...一、概述 面向对象编程和关系型数据库,都是目前最流行的技术,但是它们的模型是不一样的。 面向对象编程把所有实体看成对象(object),关系型数据库则是采用实体之间的关系(relation)连接数据。...数据库的表(table) --> 类(class) 记录(record,行数据)--> 对象(object) 字段(field)--> 对象的属性(attribute) ?...5.2 Model 的描述 Model 里面可以详细描述数据库表的定义,并且定义自己的方法(完整代码看这里)。...ORM 将这四类操作,都变成了对象的方法。 6.1 查询 前面已经说过,find()方法用于根据主键,获取单条记录(完整代码看这里)或多条记录(完整代码看这里)。

    1.3K20

    Laravel5.2之模型关联预加载

    说明:本文主要说明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问题。

    2.6K41

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

    四、查询构建器Laravel框架中的Eloquent ORM提供了方便的查询构建器,用于构建复杂的查询语句。下面是一些常用的查询构建器方法。...总结通过上述文档和示例,我们可以看出Laravel框架中的Eloquent ORM提供了便捷的对象关系映射功能,可以大大简化开发者的数据库操作。...它支持多种关联关系,包括一对一、一对多和多对多等,并且提供了方便的查询构建器,用于构建复杂的查询语句。...在使用Eloquent ORM进行开发时,需要注意以下几点:模型类名默认对应的表名是模型类名的复数形式,如User模型对应的表名是users,如果需要指定表名可以通过定义$table属性来实现。...关联关系的定义需要在对应的模型类中定义,例如一对一关联需要在hasOne和belongsTo方法中定义,一对多关联需要在hasMany和belongsTo方法中定义,多对多关联需要在belongsToMany

    1.5K41

    3分钟短文 | Laravel获取关联表指定列的3个方法

    今天我们说一说,在Laravel中,如何关联模型,以及制定返回列,以精简返回数据。 学习时间 假如有两个模型 User 和 Post,一个用户会发布多个post,也就是一对多的关联关系。...: public function user(){ return $this->belongsTo('User'); } 现在假如有一个查询,获取所有的帖子,并返回发布者的信息。...with语句 模型的with语句用于调用模型内声明的关联关系,其实它接收一个数组,可以在查询时关联多张表,同时支持一个闭包,用于对关联表的查询语句进行裁切。...关联关系 我们注意到,在关联关系的声明上,第一节仅使用了 belongTo,hasMany 这样的属性,其实还可以链式调用。这样对于所有使用 with 语句关联的模型查询,都会生效。...')); } 特殊性 在Laravel5.5及以上的版本,支持在使用with语句的使用,按照格式书写返回指定列。

    2K20

    Laravel学习记录--Model

    ,如果是单条记录获取关联关系,就需要两次查询;如果是多条记录获取关联关系,比如文章列表页获取作者信息,因为每篇文章的作者通过动态属性获取都有一次查询,所以对N条记录来说,需要N+1次查询才能返回需要的结果...,Eloquent提供了一些方法和这张表进行交互,如Stus关联了Mclass对象,在获取这些关联对象后,可以通过模型的pivot属性访问中间表数据 public function show(){...,都会被自动赋予 pivot 属性,它代表中间表的一个模型对象,能像其它的 Eloquent 模型一样使用。...:当前模型的主键 $relatedKey:关联模型类的主键,由$relate指定的模型而定义 $inverse若为true,则查询的是关联对象本身,若为false,查询的是关联对象与父模型的对应关系。...)的touches属性即可,支持添加多个关联关系 如: <?

    13.6K20

    最为常用的Laravel操作(1)-Eloquent模型

    , 这意味着主键将会被自动转化为 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 模型中访问时自动进行解密.

    35200

    Laravel5.2之Seeder填充数据小技巧

    说明:本文主要聊一聊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是一个好用的生成假数据的第三方库,而这个开发插件会自动帮你生成这些属性,不用自己写了。 <?

    3.6K42

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

    你可能注意到了我们在定义关联关系时,仅仅指定了模型类名,并没有指定通过哪些数据表字段建立关联,这并不是说 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 获取中间表字段值。

    10K40

    orm 系列 之 Eloquent演化历程1

    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属性。

    1.1K30

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

    模型类负责与数据库进行交互,这里的模型指的是数据表的模型,一个模型类对应一张数据表,数据表的字段会映射为模型类的属性,我们可以通过模型类提供的方法实现对应数据表记录的增删改查,这样一来,我们就将原来面向过程的数据库操作转化为面向对象风格的编程...我们把这种对象与数据表的映射称之为对象关系映射(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 小结 至此,我们就完成了

    2K10
    领券