一张表是文章表articles,一张表是分类表categories,其中在文章表中有一个分类字段category_id,现在想在删除分类表中的某一分类时,该分类下的所有文章也一起被删除,那么这时候就可以用到外键约束...具体用法如下: 给文章表添加外键约束 $table- unsignedInteger('category_id')- comment('文章所属分类|select'); $table- foreign...references('id')- on('categories')- onDelete('cascade'); 其中需要注意的是分类表categories中的主键字段id与文章表articles中的外键字段...category_id的数据类型或者是数据长度要保持一致,因为作为主键的id值是从1开始自增的,所以在被其绑定的外键字段的数据类型就不能使用integer,而要改用unsignedInteger 以上这篇...laravel5.6中的外键约束示例就是小编分享给大家的全部内容了,希望能给大家一个参考。
本文为作者翻译文章,原文链接:Dealing with MySQL Error Code 1215: “Cannot add foreign key constraint” 在给一个表创建外键时,MySQL...总是会出现提示: ERROR 1215 (HY000): Cannot add foreign key constraint 这信息基本是啥都没说,下面就来说说几种常见的导致1215错误的情况: 父表不存在...parent(id); ALTER TABLE child ADD FOREIGN KEY (parent_id) REFERENCES parent(`id`); 父表或者父表中相关列的名字写错了错误...parent_virt INT(10) NOT NULL, FOREIGN KEY (parent_virt) REFERENCES parent(column_virt) ) ENGINE INNODB; 创建外键失败的更多提示信息....... ------------------------ LATEST FOREIGN KEY ERROR ------------------------ 2017-06-14 21:33:55 7f6fabab7700
由于外键约束问题导致ORA-00060错误,报Single resource deadlock [TM]处理过程 这个问题持续很久,当时看到global_enqueue_deadlock,没有多看,直接认为是全局死锁...从TRACE文件中可以看到正在执行的语句如下: delete from user123.test2 where ID_=:1 经过进一步确认二者关系,表test2_abc的外键引用了表test2的主键,...但是外键没有索引 表定义如下 CREATE TABLE "user123"."...1 BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT) TABLESPACE "user123" TASK_ID_字段是外键字段引用了表...,其实Oracle建议在所有外键上都要创建索引,以避免性能问题。
在重命名表之前,需要验证该表包含的外键在迁移文件中有明确的名字,而不是Laravel基于惯例分配的名字。...否则,外键约束名将会指向旧的数据表。...Laravel 还提供了创建外键约束的支持,用于在数据库层面强制引用完整性。...外键约束和索引使用同样的命名规则——连接表名、外键名然后加上“_foreign”后缀: $table- dropForeign(‘posts_user_id_foreign'); 或者,你还可以传递在删除时会自动使用基于惯例的约束名数值数组...: $table- dropForeign([‘user_id']); 你可以在迁移时通过以下方法启用或关闭外键约束: Schema::enableForeignKeyConstraints();
在重命名表之前,需要验证该表包含的外键在迁移文件中有明确的名字,而不是 Laravel 基于惯例分配的名字。...否则,外键约束名将会指向旧的数据表。...Laravel 还提供了创建外键约束的支持,用于在数据库层面强制引用完整性。...外键约束和索引使用同样的命名规则 —— 连接表名、外键名然后加上“_foreign”后缀: $table- dropForeign('posts_user_id_foreign'); 或者,你还可以传递在删除时会自动使用基于惯例的约束名数值数组...: $table- dropForeign(['user_id']); 你可以在迁移时通过以下方法启用或关闭外键约束: Schema::enableForeignKeyConstraints(); Schema
确实看laravel的中文文档,看得糊里糊涂的。还是得在实践中理解啊。 情景假设 我有一张来源表(referers)来记录href和网页标题title。...细节 新建迁移文件就不说了。 我想说的重点是: 1、来源表和信息表可以没有任何外键约束,意思就是说各建各的,不用考虑外键什么的。...2、这两表没有任何外键关联,如果还要产生关系,那么就要第三张表来帮他们建立联系。 以上两点需要特别理解好 ---- 我前面说了,两张表(信息表、来源表)没有任何关系,那么就随便按需求建立就行。...重点是第三张表,第三张表最少需要2个字段:即两张表的外键 ? 注意: 1、你想要有其他字段也行,我们这里讨论最简单的情况。 2、第三张表的命名有要求,主要是Laravel默认情况的关系。...也最好指定以下,避免不知道的错误发送。 ? 好了,今天到这里了。
引言 使用laravel的数据库迁移功能进行表的创建,和迁移回滚之后,我们继续说说在设计中 表结构的更改之后的处理。以及如何为数据库填充一些伪数据作为测试。...[图片] 数据约束 上一章说到数据库迁移回滚,可以手动控制回滚到哪一批次的迁移位置。...我们需要空与非空约束,默认值约束,主键约束,外键约束等等数据库所具有的特性, 这才是关系型数据库的魅力。...大家应该不陌生SQL语句追加字段的语法: ALTER TABLE contacts ADD last_name varchar(40) NOT NULL AFTER contact_id; laravel...写在最后 本文是对上一章所述laravel数据库迁移功能的补充。数据库迁移是一个比较大的动作, 特别是已经上线生产的应用数据库,如果非到更新迁移的地步不可,需要预期做好演练, 以应对可能的突发事故。
开发环境:Laravel5.2 + MAMP + PHP7 + MySQL5.5 开发插件三件套 在先聊测试数据填充器seeder之前,先装上开发插件三件套,开发神器。先不管这能干些啥,装上再说。...published')->comment('文章是否发布'); $table->timestamps(); //Post表中category_id字段作为外键...* * @return void */ public function down() { //删除表时要删除外键约束,参数为外键名称...$table->increments('id'); $table->integer('post_id')->unsigned()->comment('外键...* * @return void */ public function down() { //删除表时要删除外键约束,参数为外键名称
修改表字段,接下来我们要讨论如何对表字段设置索引和外键。...所谓外键指的是一张表的字段 A 引用另一张表的字段 B,那么字段 A 就是外键,通过外键可以建立起两张表之间的关联关系,这样,数据表之间就是有关联的了,而不是一个个孤立的数据集。...在迁移类中,如果我们想建立文章表中的 user_id 字段与用户表中的 id 之间的关联关系,可以通过这种方式来定义外键索引来实现: $table->foreign('user_id')->references...('id')->on('users'); 如果你还想进一步指定外键约束(级联删除和更新,比如我们删除了 users 表中的某个 id 对应记录,那么其在文章表中对应 user_id 的所有文章会被删除...'); 注:不推荐使用外键,更不要使用外键约束功能,因为影响数据库性能,而且级联删除有可能造成非常严重的无法挽回的后果。
laravel 数据库迁移 数据迁移文件存放在database/migrations 特点:可进行版本回退,便于团队开发 通过数据迁移文件创建表 1 创建数据库 配置.env文件选择数据库 DB_CONNECTION...dateTime('created_at'); $table->double('column', 8, 2); 双精度浮点数 保留两位小数 $table->float('amount', 7,...change() 重命名字段 $table->renameColumn('from','to') 删除字段 dropCloumn('字段名') dropCloumn(['字段名','字段2']) 外键约束...当前表从表字段')->references('参考表主表字段')->on('主表') ->onDelete('cascade')//级联删除 ->update('cascade')//级联更新 默认的外键名...数据表名称_外键字段_foreign 删除外键 dropForeign('外键名') 开启/关闭外键约束 Schema::enableForeignKeyConstraints() Schema
(亲测支持表前缀),然后使用composer安装库 composer require kitloong/laravel-migrations-generator 之后使用laravel的artisan就可以逆向生成迁移文件了...视图和外键将在 +1秒内创建....时间必须通过 Carbon::parse去格式化 --table-filename[=TABLE-FILENAME] 自定义表迁移文件名,默认为: [datetime]\_create_[name]_table.php...PROC-FILENAME] 自定义存储过程迁移文件名,默认为: [datetime]\_create_[name]_proc.php --fk-filename[=FK-FILENAME] 自定义外键迁移文件名...-default-index-names 不使用数据库索引进行迁移 --default-fk-names 不使用数据库外键进行迁移 --use-db-collation 使用现有数据库排序规则生成迁移
在 Laravel 中定义模型关联是每个 Laravel 开发者可能已经做过不止一次的事情。但是在试图实现关联时可能会遇到各种问题。因为 Laravel 有各种各样的关联,你应该选择哪一个?...我们通过 hasOne 方法告诉 Laravel User 模型有一个 Passport 。 注意: 所有用于定义关联的方法都有可选的额外参数,你可以在这些参数中定义本地键和外键。...默认情况下,Laravel会假设你在用户模型中定义了 passport_id ,因为你试图创建与 passport 模型的关联。创建迁移文件时也请注意这一点!...你可以通过创建迁移文件在 Laravel 中创建此中间表。 远程关联 远程一对一 has one through 关联通过单个中间关联模型实现。...添加约束 可以在查询时向关系添加约束。看看下面的示例: <?
1.1.1 用户信息表 生成模型和迁移文件: php artisan make:model UserInfo -m 编写迁移文件(表规格): public function up() {...如果省略了第二个和第三个参数的话 Laravel根据方法名自动填充,会把第二个参数填充成 “user_id” 第三个参数填充 “id”,但是我们现在必须这样写,因为我自定义的外键是user_info_id...如果Laravel自动填充的话是找不到这个外键的 所以我们要手动的添加下。...belongsTo的第二个参数是 Account这个模型要用’user_info_id’外键去关联UserInfo模型。...》 希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
你还可以换用一种事件钩子方式,就是 Laravel 提供的 观察者(Observers)方式。...不推荐的方法 还有一种方法,我们本不打算推荐,但是考虑到有的初学者容易犯此类错误,就拿出来最为参照。 程序功能应该单一。比如,尽量避免把数据关联操作放到数据库执行。...MySQL提供了外键约束,并且可以定义触发器用于批次动作处理。...那么使用 Laravel migrations 时,创建photo表的外键关联事件: $table->foreign('user_id')->references('id')->on('users')-...写在最后 本文通过3种方式,实现了Laravel中关联删除表记录的功能。
laravel-nestedset是一个关系型数据库遍历树的larvel4-5的插件包 目录: Nested Sets Model简介 安装要求 安装 开始使用 迁移文件 插入节点 获取节点 删除节点...嵌套集合模型 安装要求 PHP>=5.4 laravel>=4.1 v4.3版本以后支持Laravel-5.5 v4版本支持Laravel-5.2、5.3、5.4 v3版本支持Laravel-5.1 v2...parent()->associate($parent)->save(); // #6 借助父节点属性 $node->parent_id = $parent->id; $node->save(); // #7...(); 其他的检查 other); other); other); $node->isLeaf() 检查一致性 你可以检查树是否被破环 $bool = Category::isBroken(); 获取错误统计...: $data = Category::countErrors(); 它将返回含有一下键的数组 oddness -- lft 和 rgt 值错误的节点的数量 duplicates -- lft 或者 rgt
我们本期要使用laravel自带的迁移功能,在不操作任何数据库的条件下,完成基础的数据构建。 迁移文件 本文假设你已经正确地配置了环境变量文件,并且通过数据库配置项,系统已经可以正常连接到数据库了。...id,还有用于记录创建时间 created_at 和 更新时间 updated_at,一个 timestamps() 方法就包含了, 只不过默认使用的是不直观的整型时间戳,如果要使用 datetime 格式用于直观地读取...其实laravel提供了齐备的命令行脚手架, 下面的方法都可以用于创建一个迁移文件: php artisan make:migration create_users_table php artisan...而在 laravel 里对一个空表修改字段,完全可以通过,我们创建新的迁移文件,然后在 up 方法内这样调用: $table->string('name', 100)->change(); 看,只用调用一个...写在最后 本文介绍了laravel中使用迁移功能操作数据库的创建,修改,移除字段,删除表等,把开发者从手动维护数据库的状态中解脱出来。这样也为团队协作时的有章可循做了铺垫。
Laravel 自带的 软删除功能 就利用全局作用域从数据库中提取「未删除」的模型。编写自定义的全局作用域可以提供一个方便、简单的方法来确保给定模型的每个查询都受到一定的约束。...如: hasOne(class,foreignkey,primarykey); class:关联模型的类名 foreignkey:关联模型的外键,如果不指定默认外键在这里默认为 muser_id...方法 并使用belongsTo方法定义反向关联 如: belongsTo(class,foreignkey,primarykey) class:反向关联的类名 foreignkey:当前模型的外键...) 如不指定,默认拼接规则为 表名_id,这里为stu_id relatedPivotKey:另一模型在中间表的字段(当前模型类的外键) 如不指定,默认拼接规则与foreignPivotKey一样 这里为...through,firstKey,secondKey,localKey,secondLocalKey) related:关联模型类throuth:中间模型类 firstKey:中间模型类与当前模型类的外键
(primary key)、外键(foreign key)、替代键(alternate key)、复合键(composite key)以及代理键(surrogate key)。...数据要没有拼写错误或不准确的记录2. 无null、非惟一或超出范围的数据记录存在 7 转换 验证转换逻辑的正确性 8 数据质量 1. 数值型验证,验证是否为数值类型2....日期型验证,验证是否为日期格式,并且在所有日期类型数据的格式应该统一3. 精度验证,小数点的精度要满足期望的精度4. 数据检查:检查数据的正确性,完整性5. null检查 9 拷贝验证 1....数学计算错误2. 最终输出错误 6 载入条件bug 1. 不运行多用户操作2. 不运行用户载入期望的数据 7 崩溃bug 1. 系统宕机或挂起2....主要验证数据是否遵循了设计预定的数据模式规则或标准 2 验证数据经过业务转换后是否满足预定的转换逻辑以及验证源和目标数据计算是否一致 主要表的主、外键等越苏是否正常 3 验证ETL过程数据表的主外键关系是否保存
引入 Laravel 框架或其组件时,应始终使用版本约束,如 ^7.0,因为 Laravel 的主要版本确实包含非兼容性更改。我们会努力确保您可以在一天或更短的时间内更新到最新版本。...支持政策 对于 LTS 版本,例如 Laravel 6,提供了 2 年的错误修复和3年的安全修复。这些版本提供了最长的支持和维护窗口。...对于一般的发行版本,只提供了 6 个月的错误修复和 1 年的安全修复。对于包括 Lumen 在内的所有其他版本,只有最新版本才会修复错误。此外,请查阅 Laravel 支持的 数据库版本。...2020 年 9 月 3 日 2021 年 3 月 3 日 Laravel 7 Laravel 7 通过引入 Laravel Sanctum,路由速度改进,自定义 Eloquent 强制转换(casts...$post; }); 隐式绑定约束 有时,当在路由中隐式绑定多个 Eloquent 模型时,可能希望对第二个 Eloquent 模型进行约束,使其必须是第一个 Eloquent 模型的子类。
领取专属 10元无门槛券
手把手带您无忧上云