场景 如果现在有两张表,一张表是文章表articles,一张表是分类表categories,其中在文章表中有一个分类字段category_id,现在想在删除分类表中的某一分类时,该分类下的所有文章也一起被删除...,那么这时候就可以用到外键约束 具体用法如下: 给文章表添加外键约束 $table- unsignedInteger('category_id')- comment('文章所属分类|select');...$table- foreign('category_id')- references('id')- on('categories')- onDelete('cascade'); 其中需要注意的是分类表categories...中的主键字段id与文章表articles中的外键字段category_id的数据类型或者是数据长度要保持一致,因为作为主键的id值是从1开始自增的,所以在被其绑定的外键字段的数据类型就不能使用integer...,而要改用unsignedInteger 以上这篇laravel5.6中的外键约束示例就是小编分享给大家的全部内容了,希望能给大家一个参考。
drop或dropIfExists方法: Schema::drop('users'); Schema::dropIfExists('users'); 通过外键重命名表 在重命名表之前,需要验证该表包含的外键在迁移文件中有明确的名字...否则,外键约束名将会指向旧的数据表。...Laravel 还提供了创建外键约束的支持,用于在数据库层面强制引用完整性。...外键约束和索引使用同样的命名规则——连接表名、外键名然后加上“_foreign”后缀: $table- dropForeign(‘posts_user_id_foreign'); 或者,你还可以传递在删除时会自动使用基于惯例的约束名数值数组...: $table- dropForeign([‘user_id']); 你可以在迁移时通过以下方法启用或关闭外键约束: Schema::enableForeignKeyConstraints();
或 dropIfExists 方法: Schema::drop('users'); Schema::dropIfExists('users'); 通过外键重命名表 在重命名表之前,需要验证该表包含的外键在迁移文件中有明确的名字...否则,外键约束名将会指向旧的数据表。...删除数据列 要删除一个列,使用 Schema 构建器上的 dropColumn 方法,同样,在此之前,确保已经安装了 doctrine/dbal 依赖: Schema::table('users',...index 'geo_state_index' }); 外键约束 Laravel 还提供了创建外键约束的支持,用于在数据库层面强制引用完整性。...外键约束和索引使用同样的命名规则 —— 连接表名、外键名然后加上“_foreign”后缀: $table- dropForeign('posts_user_id_foreign'); 或者,你还可以传递在删除时会自动使用基于惯例的约束名数值数组
每一张新表、每个新的字段、索引、以及外键都可以通过编写代码来定义,这样做的好处是在任何新环境中,你可以通过执行一个命令几秒钟就搞定项目的数据库结构。...修改表字段,接下来我们要讨论如何对表字段设置索引和外键。...A 引用另一张表的字段 B,那么字段 A 就是外键,通过外键可以建立起两张表之间的关联关系,这样,数据表之间就是有关联的了,而不是一个个孤立的数据集。...('id')->on('users'); 如果你还想进一步指定外键约束(级联删除和更新,比如我们删除了 users 表中的某个 id 对应记录,那么其在文章表中对应 user_id 的所有文章会被删除...'); 注:不推荐使用外键,更不要使用外键约束功能,因为影响数据库性能,而且级联删除有可能造成非常严重的无法挽回的后果。
本文就来说说 Laravel ORM 操作中的事件钩子。 学习时间 如果想要实现上一节所说的需求,代码写起来可能是这样的。 $user->delete(); 当该事件发生时,我们接着执行关联的删除。...这样在删除动作上只用维护一处代码,程序内所有的 delete 事件都会自动触发该动作,复用率大大地提升了。 再进一步 实现同样的需求,往往有很多种方式。...MySQL提供了外键约束,并且可以定义触发器用于批次动作处理。...那么使用 Laravel migrations 时,创建photo表的外键关联事件: $table->foreign('user_id')->references('id')->on('users')-...写在最后 本文通过3种方式,实现了Laravel中关联删除表记录的功能。
把服务绑定到服务容器上(其实还没绑定)。...composer 理解,安装laravel 1 ....命令 create-project 用以安装一个项目。我用来安装laravel。也可以从 git 上拉取指定版本。但是git拉取的,需要自己手动设置一些东西(使用命令也需要手动设置。...可以加上 –prefer-dist 参数哦,跟这个相反的是 –prefer-source.前者安装起来快一点,意思是硬盘由的话就从硬盘获取资源装上,可以避开由于安装不正确引起 git 的错误。...安装laravel例子:composer create-project laravel/laravel 项目文件夹名称 laravel版本 为啥是 laravel 是laravel/laravel 呢
引言 使用laravel的数据库迁移功能进行表的创建,和迁移回滚之后,我们继续说说在设计中 表结构的更改之后的处理。以及如何为数据库填充一些伪数据作为测试。...[图片] 数据约束 上一章说到数据库迁移回滚,可以手动控制回滚到哪一批次的迁移位置。...我们需要空与非空约束,默认值约束,主键约束,外键约束等等数据库所具有的特性, 这才是关系型数据库的魅力。...,所以laravel所组装的SQL就默认是最后一个字段之后。...写在最后 本文是对上一章所述laravel数据库迁移功能的补充。数据库迁移是一个比较大的动作, 特别是已经上线生产的应用数据库,如果非到更新迁移的地步不可,需要预期做好演练, 以应对可能的突发事故。
”这个库,但是很明显作者从2017年之后,就没有再维护过了,很显然是不适合laravel9.x去用的,所以我找到了一个可以完美平替的库 生成迁移 首先需要在config/database.php配置好数据库的连接信息...(亲测支持表前缀),然后使用composer安装库 composer require kitloong/laravel-migrations-generator 之后使用laravel的artisan就可以逆向生成迁移文件了...视图和外键将在 +1秒内创建....=PROC-FILENAME] 自定义存储过程迁移文件名,默认为: [datetime]\_create_[name]_proc.php --fk-filename[=FK-FILENAME] 自定义外键迁移文件名...-default-index-names 不使用数据库索引进行迁移 --default-fk-names 不使用数据库外键进行迁移 --use-db-collation 使用现有数据库排序规则生成迁移
按照Laravel设定好的模式来写关联模型每个人都能写出高效和优雅的代码 (这点我认为适用于所有的Laravel特性)。...,按照约定Eloquent 默认使用父级模型名的「snake case」形式、加上 _id 后缀名作为外键字段。...'user_id', // 文章表外键... 'id', // 国家表本地键......$this->firstKey = $firstKey;//用户表中的外键country_id $this->secondKey = $secondKey;//文章表中的外键...models); } return $this->related->newCollection($models); } } 关联方法 出了用动态属性加载关联数据外还可以在定义关联方法的基础上再给关联的子模型添加更多的
1.2、约束作用 对表中的数据进行限制,保证数据的正确性、有效性和完整性。一个表如果添加了约束,不正确的数据将无法插入到表中。约束在创建表的时候添加比较合适。...自增长只能用在主键上 非空与唯一约束可以设置在N个字段上 六、默认值 默认值就是:当我们在增加记录的时候如果不去设置值,那么自动的会用默认值补齐,字段默认的默认值是null 6.1、默认值格式 字段名...解决方法: 使用外键约束 7.4、什么是外键约束 一张表的一个字段受限于另外一张表的一个字段对应的值。这里涉及到两张表:被引用的表叫主表(父表),另外一张叫从表(子表)。...**子表:**定义了外键的表,外键的取值要么取父表中字段对应的值,要么取NULL值,严重受限于父表 **父表:**被引用的字段要具有唯一性(绝大多数都是用的父表的主键) 八、外键约束 8.1、外键约束格式...格式一: [constraint][外键约束名称] foreign key(外键字段名) references 主表名称(主键字段名); #在create table时设置 案例: 创建一个班级表
前言 之前,在文章:https://www.misiyu.cn/article/58.html 已经发过关于Laravel中的多对多关系了。 但回过头来,过了个把月再去看,我自己都忘了怎么写了。...确实看laravel的中文文档,看得糊里糊涂的。还是得在实践中理解啊。 情景假设 我有一张来源表(referers)来记录href和网页标题title。...目前需求是信息表里面的多个信息可能同属于来源表中的一条记录。 同样,来源表中的多条信息可能属于信心表中的一条记录。 简言之就是,这是多对多的关系。 细节 新建迁移文件就不说了。...我想说的重点是: 1、来源表和信息表可以没有任何外键约束,意思就是说各建各的,不用考虑外键什么的。 2、这两表没有任何外键关联,如果还要产生关系,那么就要第三张表来帮他们建立联系。...重点是第三张表,第三张表最少需要2个字段:即两张表的外键 ? 注意: 1、你想要有其他字段也行,我们这里讨论最简单的情况。 2、第三张表的命名有要求,主要是Laravel默认情况的关系。
说明:本文主要聊一聊Laravel测试数据填充器Seeder的小技巧,同时介绍下Laravel开发插件三件套,这三个插件挺好用哦。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...* * @return void */ public function down() { //删除表时要删除外键约束,参数为外键名称...$table->increments('id'); $table->integer('post_id')->unsigned()->comment('外键...* * @return void */ public function down() { //删除表时要删除外键约束,参数为外键名称...分享下最近发现的一张好图和一篇极赞的文章: 文章链接:Laravel的中大型專案架構
在渴求式加载中,也可以通过闭包传入额外的约束条件,只不过这个约束条件是对关联模型自身的过滤,不影响目标模型的查询: $post = Post::with(['comments' => function...>orderBy('created_at', 'desc'); }]); 关联插入与更新 一对多关联记录插入 新增关联模型的时候,可以在父模型上调用相应方法直接插入记录到数据库,这样做的好处是不需要指定关联模型与父模型的外键关联字段值...=> mt_rand(1, 15)], ['content' => $faker->paragraph, 'user_id' => mt_rand(1, 15)] ]); 更新一对多所属模型外键字段...如果是要更新新创建的模型实例所属模型(父模型)的外键字段,比如以 posts 表为例,新增的记录想要更新 user_id 字段,可以这么实现: $user = User::findOrFail(1);...空对象模型 如果外键字段 user_id 允许为空的话,当我们访问 Post 模型上的 author 属性时,默认返回为 null。
在 Laravel 中定义模型关联是每个 Laravel 开发者可能已经做过不止一次的事情。但是在试图实现关联时可能会遇到各种问题。因为 Laravel 有各种各样的关联,你应该选择哪一个?...如果你不完全理解 Laravel 的关联在这一点上是如何工作的,别担心,读完这篇文章后,你会更好地理解它。 我们应该使用哪个模型关联? 要回答这个问题,首先你要知道有哪些可用的选项。...我们通过 hasOne 方法告诉 Laravel User 模型有一个 Passport 。 注意: 所有用于定义关联的方法都有可选的额外参数,你可以在这些参数中定义本地键和外键。...在 User 模型的每个实例上,我们都可以得到对应的 Passport 和 Invoice。 <?...添加约束 可以在查询时向关系添加约束。看看下面的示例: <?
图形化界面备份与还原 数据库表的约束 数据库约束的概述 主键约束 唯一约束 非空约束 默认值 外键约束 表与表之间的关系 表关系的概念 一对多 多对多 一对一 数据库设计 数据规范化 1NF 2NF...一个表如果添加了约束,不正确的数据将无法插入到表中。约束在创建表的时候添加比较合适。...什么是外键约束: 什么是外键:在从表中与主表主键对应的那一列,如:员工表中的 dep_id 主表: 一方,用来约束别人的表 从表: 多方,被别人约束的表 创建约束的语法: 1、新建表时增加外键...: [CONSTRAINT] [外键约束名称] FOREIGN KEY(外键字段名) REFERENCES 主表名(主键字段名) 2、已有表增加外键: ALTER TABLE 从表 ADD [CONSTRAINT...两种建表原则: 一对一的建表原则 说明 外键唯一 主表的主键和从表的外键(唯一),形成主外键关系,外键唯一 UNIQUE 外键是主键 主表的主键和从表的主键,形成主外键关系 数据库设计 数据规范化 什么是范式
1.Laravel在truncate表的时候,如果有外键,先把约束检查关掉再清空表。
Laravel 自带的 软删除功能 就利用全局作用域从数据库中提取「未删除」的模型。编写自定义的全局作用域可以提供一个方便、简单的方法来确保给定模型的每个查询都受到一定的约束。...如: hasOne(class,foreignkey,primarykey); class:关联模型的类名 foreignkey:关联模型的外键,如果不指定默认外键在这里默认为 muser_id...foreignkey:当前模型的外键 primarykey:父表的主键 <?...使用渴求式加载,即根据预先需求查询出所有数据 为了验证[渴求式加载]的好处,举下列例子 这里用到了Laravel Debugbar 调试 安装方法可参照我的另一个博客 - - - Laravel...为null,前提是uid字段允许为空,如果不允许为空会抛出异常 空对象模型 如果外键字段uid允许为空,当我们访问Phone模型上的muser属性(注意这里是属性,而不是方法)时,默认返回null,Eloquent
表级约束,对过个数据列建立的约束;列级约束,对一个数据列建立的约束。...功能分: not null 非空约束 primary key 主键约束 unique key 唯一约束 default 默认约束 foreign key 外键约束 外键约束实现一对一或一对多的关系。...创建外键约束,父表和子表必须要有相同的存储引擎,而且禁用临时表,具有外键列的表称为子表,子表所参照的表为父表。 数据库的存储引擎只能为InnoDB。...外键列和参照列必须具有相同的数据类型,外键列,参照列。 外键列和参照列必须创建索引,如果外键列不存在索引的话,mysql将自动创建索引,参照列不存在索引,不会自动创建索引。...外键列不创建,会自动创建,子;参照列不创建的话,不会自动创建,为父。 结言 好了,欢迎在留言区留言,与大家分享你的经验和心得。
目前,Laravel 支持四种类型的数据库系统: MySQL Postgres SQLite SQL Server 配置 Laravel 让连接数据库和运行查询都变得非常简单。...默认情况下,Laravel 示例环境配置已经为 Laravel Homestead 做好了设置,当然,你也可以按照需要为本地的数据库修改该配置。...read和write,这两个键都对应一个包含单个键“host”的数组,读/写连接的其它数据库配置选项都共用 mysql 的主数组配置。...,通常,这些都是where字句约束中的值。...传递给connection方法的连接名对应配置文件config/database.php中相应的连接: $users = DB::connection('foo')- select(...); 你还可以通过连接实例上的
经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...:优化前5条sql,优化后2条sql laravel-upsert 扩展的特性 安装 composer require staudenmeir/laravel-upsert:"^1.0" 用法 插入和更新...第二个参数是唯一标识记录的列。除 SQL Server 外的所有数据库都要求这些列具有PRIMARY或UNIQUE索引。 提供要更新的列作为第三个参数(可选)。默认情况下,将更新所有列。...作为使用复合键和原始表达式的示例,请考虑以下表,该表计算每个帖子和每天的访问者: Schema :: create ( 'stats' , function ( Blueprint $ table )...LaravelUpsert\Eloquent\HasUpsertQueries; 因为我们数据库的时间是int类型,不是laravel默认的时间格式,并且我们的插入时间和更新时间也不是laravel默认的字段
领取专属 10元无门槛券
手把手带您无忧上云