引言 使用laravel的数据库迁移功能进行表的创建,和迁移回滚之后,我们继续说说在设计中 表结构的更改之后的处理。以及如何为数据库填充一些伪数据作为测试。...[图片] 数据约束 上一章说到数据库迁移回滚,可以手动控制回滚到哪一批次的迁移位置。...很多时候,并不是说我们创建了表,并且指定了字段名,和字段数据类型就算完事儿了。 我们需要空与非空约束,默认值约束,主键约束,外键约束等等数据库所具有的特性, 这才是关系型数据库的魅力。...,与之前讲的创建迁移文件相同, 首先创建一个迁移文件,使用以下脚手架指令: php artisan make:migration add_enabled_to_events_table --table=..., 我们仅仅是添加一个字段,或者在回滚的时候,删除一个字段,代码如下图: [pic] 完成后在命令行执行迁移指令: php artisan migrate 输出结果如下: Migrating: 2020
引言 laravel模型不但提供了可供数据库操作的增删改查,还附加了很多功能,最关键的要数模型的关联关系。本文说一说简单的一对一,和一对多关系。用代码说话,让大家更直观地理解。...$this->hasOne(PhoneNumber::class); }} 上面这个写法,默认是有一个模型 PhoneNumber 所对应的表,且表内有一个字段名 contacts_id 作为外键...如果这个外键不是 contacts_id,那就手动指定: return $this->hasOne(PhoneNumber::class, 'owner_id'); 使用 phone_numbers 表的...Model{ public function contact() { return $this->belongsTo(Contact::class); }} 与上方的调用关系相同...我们只需在关联关系基础上,链式调用save方法,传入一个关联模型实例。如果要写入多条的,就传入一个 关联模型实例的数组。
本文实例讲述了Laravel5.1 框架模型一对一关系实现与使用方法。分享给大家供大家参考,具体如下: 这篇文章主要记录模型的一对一关系,关联关系是Model的一种非常方便的功能。...$table- timestamps(); }); } 2 编写关系 首先是账号表,在模型下编写以下代码: public function user() { return...如果省略了第二个和第三个参数的话 Laravel根据方法名自动填充,会把第二个参数填充成 “user_id” 第三个参数填充 “id”,但是我们现在必须这样写,因为我自定义的外键是user_info_id...如果Laravel自动填充的话是找不到这个外键的 所以我们要手动的添加下。...belongsTo的第二个参数是 Account这个模型要用’user_info_id’外键去关联UserInfo模型。
设计字段 按照上文提到的Category、Post、Comment和Tag之间的关系创建迁移Migration和模型Model,在项目根目录输入: php artisan make:model Category...category_id字段作为外键,与Category一对多关系 $table->foreign('category_id') ->references...post_id字段作为外键,与Post一对多关系 $table->foreign('post_id') ->references('id')...Tag表是多对多关系,还需要一张存放两者关系的表: //多对多关系,中间表的命名laravel默认按照两张表字母排序来的,写成tag_post会找不到中间表 php artisan make:migration...表的关系如下: Seeder填充测试数据 好,在聊到seeder测试数据填充之前,看下开发插件三件套能干些啥,下文中命令可在项目根目录输入php artisan指令列表中查看。
应用Active Record时,每一个类的实例对象唯一对应一个数据库表的一行(一对一关系)。...Installation: composer require barryvdh/laravel-debugbar --dev 二、一对一关系映射 2.1 创建表 public function up()...$table->string('phone'); $table->unsignedInteger('user_id'); //显示的声明外键...:通知数据库根据外键关联表和建立索引,提高运行速度 $table->foreign('user_id') ->references('id')...自定义外键: return $this->hasOne(Profile::class,'显示指定自定义外键'); 2.4 一对一测试 依赖注入Request $request,获取当前登录用户$request
前言 之前,在文章:https://www.misiyu.cn/article/58.html 已经发过关于Laravel中的多对多关系了。 但回过头来,过了个把月再去看,我自己都忘了怎么写了。...简言之就是,这是多对多的关系。 细节 新建迁移文件就不说了。 我想说的重点是: 1、来源表和信息表可以没有任何外键约束,意思就是说各建各的,不用考虑外键什么的。...2、这两表没有任何外键关联,如果还要产生关系,那么就要第三张表来帮他们建立联系。 以上两点需要特别理解好 ---- 我前面说了,两张表(信息表、来源表)没有任何关系,那么就随便按需求建立就行。...重点是第三张表,第三张表最少需要2个字段:即两张表的外键 ? 注意: 1、你想要有其他字段也行,我们这里讨论最简单的情况。 2、第三张表的命名有要求,主要是Laravel默认情况的关系。...当然,搞不懂默认关系,我们在模型关联的时候指定表明就行。
场景 用户之间相互关注,记录这种关系的是followers表(follower_id 发起关注的人 followed_id被关注的人) 现在的多对多的关系就不再是传统的三张表的关系了, 这种情况 多对多关系应该怎么声明呢...分析 laravel或者其他框架多对多的关系 一般都是由Model1 Model2 Model1_Model2(声明两者关系的表)来组成, 但是上面的场景 却是只有两张表,这时候就要研究下官方文档了...; 当然是支持的 参考资料 https://laravel.com/docs/5.6/eloquent-relationships#many-to-many In addition to customizing...以达到个性化的需求, 第一个参数是 第二个Model 第二个参数是 关系表名 第三个参数是 第一个Model在关系表中的外键ID 第四个参数是 第二个Model在关系表中的外键ID 解决...关系表名是 ‘followers’ /** * 关注当前用户的 * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
在 Laravel 中定义模型关联是每个 Laravel 开发者可能已经做过不止一次的事情。但是在试图实现关联时可能会遇到各种问题。因为 Laravel 有各种各样的关联,你应该选择哪一个?...如果你不完全理解 Laravel 的关联在这一点上是如何工作的,别担心,读完这篇文章后,你会更好地理解它。 我们应该使用哪个模型关联? 要回答这个问题,首先你要知道有哪些可用的选项。...我们通过 hasOne 方法告诉 Laravel User 模型有一个 Passport 。 注意: 所有用于定义关联的方法都有可选的额外参数,你可以在这些参数中定义本地键和外键。...在 User 模型的每个实例上,我们都可以得到对应的 Passport 和 Invoice。 <?...添加约束 可以在查询时向关系添加约束。看看下面的示例: <?
个人对于laravel orm 中对于一对多关系的理解 文章表 article,文章自然可以评论,表 comment 记录文章的评论,文章和评论的关系就是一对多,一篇文章可以有多个评论。...在 comment 表中有字段article 记录评论所属文章,文章和评论的关系如下: article:id … … comment : id … … article_id 在 comment 表中有关联...article 的外键 article_id,所以在 Comment 模型中是 belongsTo方法,在 Article 模型中是hasMany方法 在文章的模型 Article 中,则可以有如下的方法来关联评论...'(这里是关联外键的字段名,这个例子就是 article_id 字段), ‘id'(对应关联模型的主键,这里的 id 是关联 article 表的id)); } 对应的在 Comment 模型中,则可以有如下的方法来关联文章...'(这里是关联外键的字段名,这个例子就是 article_id 字段), ‘id'(对应关联模型的主键,这里的 id 是关联 article 表的id)); } 以上这篇浅谈laravel orm 中的一对多关系
IGNORE 的支持 先简单说明一下业务场景: 首先表结构设计是:互相喜欢和添加联系人都是双向关系,即入库A B,B A这样成对的双向数据 触发互相喜欢,插入2条双向数据,插入之前校验是否存在,存在不重复添加...(UPSERT) 考虑这个users具有唯一username列的表: Schema :: create ( 'users' , function ( Blueprint $ table ) {...第二个参数是唯一标识记录的列。除 SQL Server 外的所有数据库都要求这些列具有PRIMARY或UNIQUE索引。 提供要更新的列作为第三个参数(可选)。默认情况下,将更新所有列。...作为使用复合键和原始表达式的示例,请考虑以下表,该表计算每个帖子和每天的访问者: Schema :: create ( 'stats' , function ( Blueprint $ table )...1 ], ], [ 'post_id','日期' ], [ 'views' => DB :: raw ( 'stats.views + 1' )] ); 插入忽略 您还可以在忽略重复键错误的同时插入记录
外键是表的一个字段,不是本表的主键,但对应另一个表的主键。定义外键后,不允许删除另一个表中具有关联关系的行。 外键的主要作用是保持数据的一致性、完整性。...---- 主表和从表 主表(父表):对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表。 从表(子表):对于两个具有关联关系的表而言,相关联字段中外键所在的表就是从表。...也就是说,只要外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。 外键中列的数目必须和父表的主键中列的数目相同,因为有组合主键和组合外键。...外键中列的数据类型必须和父表主键中对应列的数据类型相同。...id值 ---- 小总结 被约束的表成为副表,约束别人的表成为主表,外键设置在副表上 主表(参考表)的参考字段通常为主键 添加数据时,必须先添加主表,后添加副表 修改数据时,必须先修改副表,再修改主表
关系模型 外键 在 students 表中,通过 class_id 的字段,可以把数据与另一张表关联起来,这种列称为外键。...(id) 指定了这个外键将关联到 classes 表的 id 列(即 classes 表的主键)。...通过定义外键约束,关系数据库可以保证无法插入无效的数据。即如果 classes 表不存在 id=99 的记录,students 表就无法插入 class_id=99 的记录。...,即该列的值如果越互不相同,那么索引效率越高。...在设计关系数据表的时候,看上去唯一的列,例如身份证号、邮箱地址等,因为他们具有业务含义,因此不宜作为主键。但是,这些列根据业务要求,又具有唯一性约束:即不能出现两条记录存储了同一个身份证号。
不过相对来说,模型需要每个表都建立,而且表间关系复杂的话 Model 类也会比较复杂,而查询构造器会更简单而且更方便使用。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。...一般的连表查询,我们只需要一个外键相对应即可,但是在我的实际业务开发中,还会有遇到多个键相对应的情况,这个才是我们接下来说的重点问题。...`sex` }); 代码中第一段的连表查询就是最普通的一个外键的查询,如果要实现多个外键连表的话,就需要使用第二种方法。...总结 关于 查询构造器 的其它使用在官方文档上都有,今天的文章就只是简单地介绍了一些常用的和独特的查询构造方式而已,毕竟我们的系列文章的主旨还是在分析源码上。
细节维度和维度子集具有相同的属性或内容,具有一致性。 1.建立包含属性子集的子维度 比如需要上钻到子维度。...例如,事实表可以有多个日期,每个日期通过外键引用不同的日期维度,原则上每个外键表示不同维度视图,这样引用具有不同的含义。...这些不同的维度视图具有唯一的代理键列名,被称为角色,相关维度被称为角色扮演维度。...因为相同的商户会放到同一个reducer去处理。...层次关系方法:固定深度层次进行分组和钻取查询,递归层次结构数据装载、展开与平面化,多路径层次和参差不齐处理 五.退化维度 除了业务主键外没有其他内容的维度表。
在对数据库进行操作之前,需要先创建数据表,在诸如 Laravel 这种现代框架中,通过代码驱动让数据表结构的定义变得非常简单。...up 方法和 down 方法和之前通过指定 --create= 选项创建的方法不一样,因为这个迁移文件是用于修改数据表,对应的,我们只需在已有 users 表基础上增删字段即可,不需要新增或删除数据表...A 引用另一张表的字段 B,那么字段 A 就是外键,通过外键可以建立起两张表之间的关联关系,这样,数据表之间就是有关联的了,而不是一个个孤立的数据集。...在迁移类中,如果我们想建立文章表中的 user_id 字段与用户表中的 id 之间的关联关系,可以通过这种方式来定义外键索引来实现: $table->foreign('user_id')->references...('id')->on('users'); 如果你还想进一步指定外键约束(级联删除和更新,比如我们删除了 users 表中的某个 id 对应记录,那么其在文章表中对应 user_id 的所有文章会被删除
事实来自业务过程的度量,基本上以数量值表示。...对于事实表,还有一类值NULL,需要我们去校验和保证,对于事实表的度量,我们可以允许存在NULL,不过对于一些外键,则不能存在空值,否在会导致违反参照完整性的情况发生,我们可以赋予默认的代理键来表示未知或者...如果一个度量出现在多个事实表里面,我们还需要保证,多个事实表汇总到同一个维度的时候,度量的值相等,并且命名尽量相同,这就是一致性事实。一致性事实可以保证数据口径的一致和取数方便。...维度表的主键可以作为与之关联的任何事实表的外键,当然,维度表行的描述环境与事实表行完全对应。 维度表开发过程中有下面几个点。...一致性维度,当不同的维度表的属性具有相同列名和领域内容时,称维度具有一致性。利用一致性维度属性与每一个事实表关联,可将来自不同事实表的信息合并到同一个报表里面。
使用模型关联给应用开发带来的收益我认为有以下几点 主体数据和关联数据之间的关系在代码表现上更明显易懂让人一眼就能明白数据间的关系。...;//关联模型Role的主键在中间表中的外键role_id $this->foreignPivotKey = $foreignPivotKey;//父模型Role的主键在中间表中的外键user_id...,与定义一对多关联时一样,实例化BelongsToMany时定义里与关联相关的配置:中间表名、关联的模型、父模型在中间表中的外键名、关联模型在中间表中的外键名、父模型的主键、关联模型的主键、关联关系名称...'user_id', // 文章表外键... 'id', // 国家表本地键......id $this->firstKey = $firstKey;//用户表中的外键country_id $this->secondKey = $secondKey;//文章表中的外键
引言 本期我们把目光投向laravel模型的关联关系上。...因为关联关系的第二个,第三个参数,根本没有填写。所以这样对比是不直观的。 hasOne 和 belongsTo 最大的不同,是哪一方持有关系的外键。...举个例子,比如User表,还有一个 Car表,为了简化逻辑关系, 我们假设一个user只有一个car。我们在car表内设计一个 user_id 字段,用于存储 user 表的 id 值。...return $this->belongsTo('User', 'user_id', 'id'); } } 所以,反向关系无关于原始的一对一,或者一对多,因为数据库表内存储了外键,所以使用这个...写在最后 本文通过几个实例介绍了数据库模型的一对一,一对多,以及反向关联关系, 大家记住一点,belongsTo 是根据当前表存储的外键,去主表内查找记录,而且是返回一个模型对象,或者null。
这是我是文章表【articles】、标签表【tags】以及关系表【article_tag】 其中关系的命名是[article_tag]而不是tag_article 因为laravel默认是以字母升序排列...可以在定义的时候设置,但何必那么麻烦,按照默认规则来不是很好么? 另外就是,新建迁移文件的顺序也有要求,关系表肯定是最后的,然后文章表和标签表好像随意,但我是先建文章表。...这里有外键,但是是其他外键,不关我们这里要讲的。 新建标签表 php artisan make:model Model/Tag -m 我是新建模型的时候就顺带穿件迁移表了。 ?...可以看出没有外键。 新建关系表 php artisan make:migration create_article_tag_table --create=article_tag ?...这里有两个外键,分别是文章表的主键和标签表的主键。
关系不是通过描述其内涵来刻画事物间联系的,而是通过列举其外延(具有这种联系的对象组合全体)来描述这种联系 B:笛卡尔积 关系的概念是建立在笛卡尔积概念的基础上的,笛卡尔积是定义在给定一组域上的有序对的集合...(集)上取值不同 构成候选键的属性(集)的值对于关系的所有实例都具有惟一性,而不是只针对某一个实例 通常在关系模式中在构成候选键的属性(集)下面画下划线,来表明它是键的组成部分 学生(姓名,性别,年龄)...上的分量值也是关系S中某个元组的Ks上的分量值,则称该属性(集)F为关系R的外键 R为参照关系(引用关系),S为被参照关系或目标关系 关系R和关系S可以是同一个关系 目标关系的主键Ks和参照关系R的外码...F的命名可以不同,但必须定义在同一(或同一组)域上 是不是感觉更加复杂了,别急先看下面的例题,看完题目,再回过头来看候选键和外键的两个概念就好多了 【例】学生实体和课程实体分别用关系“学生”和“课程”来表示...(3) 参照完整性 在关系模型中实体以及实体间的联系都是用关系来描述的 关系之间的参照一般通过外键来描述,并遵循如下约束规则 参照完整性规则: 若属性(或属性集)F是关系R的外键,它与关系S的主键Ks
领取专属 10元无门槛券
手把手带您无忧上云