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

删除数据库中未指定名称的外键的存储过程

数据库中的某个表A,因为业务原因被移到别的库。麻烦的是,有几张子表(B, C, D等)建有指向它的外键,而且在创建时没有指定统一的外键名。...如此一来,在不同的环境(开发、测试、生产等)中该外键的名称不一样,必须逐个去查询外键名再进行删除,十分不便。...为此,特地编写了一个存储过程,只须指定子表名(B,C,D)和外键的列名,直接调用该存储过程即可。...Oracle的存储过程代码如下: -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE OR REPLACE PROCEDURE DROP_FK(P_TABLE IN VARCHAR2,...: -- 删除指定表、指定列上的外键(系统命名或未知名) CREATE OR REPLACE FUNCTION DROP_FK(P_TABLE IN VARCHAR, P_COLUMN IN VARCHAR

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

    数据库的外键到底能不能用?

    我们在数据库库设计的时候,可能会使用到外键约束这个属性,它是从数据库的层面对表之间的关系进行了约束,但是如果使用不正确,就可能带来一些隐患,例如Oracle中,我们熟知的某些场景下,如果外键无索引,就可能导致锁表...杨老师写的这篇文章《第05期:外键到底能不能用?》以MySQL的视角,介绍了外键设计的种种场景,可以帮助我们进行数据库设计的时候,用正确的姿势用外键。...那先来简单看看 MySQL 里外键的用法。MySQL 外键仅有 InnoDB 和 NDB 两种引擎支持,这里只关注 InnoDB。...不支持虚拟列。 3. 不支持临时表。 4. 外键列以及引用列数据类型、字符集、校对规则都得一致。 5. 外键列以及引用列都必须建立索引。 6. 外键引用多个列的,列顺序必须一致。 7....大对象字段不能作为引用列。 8. constraint 命名必须在单个 database 里唯一。 9. 外键级联更新操作不会触发子表上的触发器。 10. 不支持分区表。

    87850

    数据库不使用外键的 9 个理由

    我的经验告诉我,很多数据库(大多数我曾经使用的)不包含外键时并不总是一件坏事。在这篇文章中,我想把重点放在为什么的原因上。 为什么这是一个问题? 1....表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...跨数据库关系 这可能不是数据库没有外键的正确理由,一些数据库跨越更多的物理数据库甚至引擎,并且在技术上可能不能创建跨越数据库的它不能在同一台服务器上的两个数据库上创建key。...SQL Server就是一个很好的例子 - 它不能在同一台服务器上的两个数据库上创建key。而且这种架构在大型系统中很常见。 6....懒惰的架构师 在创建数据库时,如果要存储数据,则需要创建一些表和列。这是最低限度。但是,您不必创建保持数据一致性的结构,如主键,唯一键,外键或约束。这需要一些努力,但是却没有带来直接的好处。

    1.2K10

    数据库外键的作用,以及和主键的区别

    http://blog.csdn.net/tiantian1980/article/details/1603126 外键是数据库一级的一个完整性约束,就是数据库基础理论书中所说的“参照完整性”的数据库实现方式...例如有两个表      A(a,b)   :a为主键,b为外键(来自于B.b)      B(b,c,d)   :b为主键       如果我把字段b的外键属性去掉,对编程没什么影响。  ...如上面,A中的b要么为空,要么是在B的b中存在的值,有外键的时候,数据库会自动帮你检查A的b是否在B的b中存在。   1、外建表达的是参照完整性:这是数据固有的,与程序无关。...2、使用外建,简单直观,可以直接在数据模型中体现,无论是设计、维护等回有很大的好处,特别是对于分析现有的数据库的好处时非常明显的--前不久我分析了一个企业现有的数据库,里面的参照完整性约束有的是外键描述...比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。

    6K21

    数据库不推荐使用外键的9个理由

    来源:www.jdon.com/49188 我的经验告诉我,很多数据库(大多数我曾经使用的)不包含外键时并不总是一件坏事。在这篇文章中,我想把重点放在为什么的原因上。 为什么这是一个问题?...2.表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...5.跨数据库关系 这可能不是数据库没有外键的正确理由,一些数据库跨越更多的物理数据库甚至引擎,并且在技术上可能不能创建跨越数据库的它不能在同一台服务器上的两个数据库上创建key。...SQL Server就是一个很好的例子 - 它不能在同一台服务器上的两个数据库上创建key。而且这种架构在大型系统中很常见。...也许这个原因和以前一样,或者是下一个原因: 8.懒惰的架构师 在创建数据库时,如果要存储数据,则需要创建一些表和列。这是最低限度。但是,您不必创建保持数据一致性的结构,如主键,唯一键,外键或约束。

    2.1K10

    数据库不推荐使用外键的 9 个理由

    2.表格关系不清晰 数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。 为什么数据库可以没有外键?...让我们来看看数据库可以没有外键的原因。首先一个简短的免责声明(因为文章引发了一些关于LinkedIn群体的争议): 下面的理由绝不鼓励不要在数据库中使用外键约束。...5.跨数据库关系 这可能不是数据库没有外键的正确理由,一些数据库跨越更多的物理数据库甚至引擎,并且在技术上可能不能创建跨越数据库的它不能在同一台服务器上的两个数据库上创建key。...SQL Server就是一个很好的例子 - 它不能在同一台服务器上的两个数据库上创建key。而且这种架构在大型系统中很常见。...也许这个原因和以前一样,或者是下一个原因: 8.懒惰的架构师 在创建数据库时,如果要存储数据,则需要创建一些表和列。这是最低限度。但是,您不必创建保持数据一致性的结构,如主键,唯一键,外键或约束。

    1.7K30

    Django学习-第七讲:django 中的常用字段、字段属性,外键和表关系、外键操作

    映射到数据库中是longtext类型。 16. UUIDField 只能存储uuid格式的字符串。uuid是一个32位的全球唯一的字符串,一般用来作为主键。 17....外键和表关系 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关系的时候异常的强大。...比如有一个Category和一个Article两个模型。一个Category可以有多个文章,一个Article只能有一个Category,并且通过外键进行引用。...即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。 3.SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。...那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。

    4K30

    Excel中两列(表)数据对比的常用方法

    Excel中两列数据的差异对比,方法非常多,比如简单的直接用等式处理,到使用Excel2016的新功能Power Query(Excel2010或Excel2013可到微软官方下载相应的插件...vlookup函数除了适用于两列对比,还可以用于表间的数据对比,如下图所示: 三、使用数据透视进行数据对比 对于大规模的数据对比来说,数据透视法非常好用,具体使用方法也很简单,即将2列数据合并后...Query进行的数据对比,可以随着数据源的更新而达到一键更新对比结果的效果。...比如,有两个表的数据要天天做对比,找到差异的地方,原来用Excel做虽然也不复杂,但要频繁对比,就很麻烦了,因此,可以考虑使用Power Query来实现直接刷新的自动对比。...Excel里了 在线M函数快查及系列文章链接(建议收藏在浏览器中): https://app.powerbi.com/view?

    16.4K20

    MySQL中创建外键的错误:1215 Cannot add the foreign key constraint

    引言: MySQL中经常会需要创建父子表之间的约束,这个约束是需要建立在主外键基础之上的,这里解决了一个在创建主外键约束过程中碰到的一个问题。 1....碰到错误 在创建外键之时,使用的SQL和碰到错误信息如下: alter table `product' add CONSTRAINT `sid_ref` FOREIGN KEY (`sid`)...REFERENCES `sealer` (`id`) ON DELETE NO ACTION ON UPDATE NO ACTION 碰到的错误信息如下: 无法正确的插入外键约束。...问题分析 主外键更多的是某表的主键与子表的某个列进行关联,要求是具备相同的数据类型和属性,问题会不会出现在这里?...解决的办法 修改product.sid中的数据类型,添加unsigned和字段的长度,将其设置为相同即可。 5.

    2.5K50

    Django 外键引用另一个表中的多个字段

    在 Django 中,外键(ForeignKey)通常只引用另一张表的一个字段,比如一个主键或一个唯一标识字段。然而,如果我们需要让一个外键引用另一张表中的多个字段,通常有以下几种方法来实现这种关系。...1、问题背景在 Django 中,模型之间的关系通常使用外键(ForeignKey)来建立。外键允许一个模型中的字段引用另一个模型中的主键。然而,有时我们需要在一个模型中引用另一个模型中的多个字段。...以下是如何在 Django 中使用复合主键来实现外键引用另一个表中的多个字段:在 product_models 模型中,添加一个 id 字段作为主键:class product_models(models.Model...添加一个 product 字段作为外键,并使用 MultipleFieldPrimaryKeys 选项来定义复合主键:class sales_process(models.Model):​ prospect...划重点Django 不直接支持复合外键,但可以通过添加唯一约束、使用中间表或在查询中使用逻辑约束来实现类似效果。

    10510

    oracle基础|数据库如何设计|数据库的六种范式|数据库的主键和外键|数据库的约束

    目录 一、数据库设计 二、数据库六种范式 第一范式: 第二范式: 第三范式: 三、主键和外键 主键: 外键: 四、完整性约束 五、建表 六、oracle数据库中的多种数据结构 ---- 一、数据库设计...数据建模完成之后,可以把ER图转换成数据中的表 1.实体的名字转换为表的名字 2.实体的属性转换为表中的列 3.具有唯一特点的属性设置为表中的主键 4.根据实体之间的关系设置为表中某列为外键列(主外键关联...,要求这几个列的值联合在一起是非空唯一的 外键: 1.表中的某一个列声明为外键列,一般这个外键列的值都会引用于另外一张表的主键列的值(有唯一约束的列就可以,不一定非要引用主键列) 2.另外一张表的主键列中出现过的值都可以在外键列中使用...3.外键列值也可以为空的,提前是这个外键列在表中不做主键,因为我们也可以把表中的外键列当做主键来使用(只有满足非空唯一的要求就可以) 4.如果把B表中的联合主键的值引用到A表中做外键,因为是俩个列在B...表中做联合主键,那么A表引用过来的时候也要把俩个列的值都引用过来,那么它们在A表中就会作为一个联合外键出现 四、完整性约束 实体完整性: 引用完整性 列级完整性 用户自定义 五、建表 1.映射实体---

    72940

    【Django 2.2文档系列】Model 外键中的on_delete参数用法

    场景 我们用Django的Model时,有时候需要关联外键。关联外键时,参数:on_delete的几个配置选项到底是干嘛的呢,你知道吗? 参数介绍 models.CASCADE 级联删除。...比如:用户的有一个外键关联的是用户的健康记录表,当用户删除时,配置了这个参数的健康记录表中跟这个用户有关的数据也会被删除。...当数据被删除时,被关联的外键内容被设置为null。 models.SET_DEFAULT 将外键的值设置为默认值。外键必须设置有默认值 。...models.SET()将SET()设置的值作为外键的值 ,如果传递了callable,则调用它的结果。 DO_NOTHING不采取行动。...如果后端数据库有强制关联操作,这是容易报错:IntegrityError,除非你在数据库中手动添加了SQL的ON DELETE约束。

    2K10

    SQL Server 数据库调整表中列的顺序操作

    SQL Server 数据库中表一旦创建,我们不建议擅自调整列的顺序,特别是对应的应用系统已经上线,因为部分开发人员,不一定在代码中指明了列名。...表是否可以调整列的顺序,其实可以自主设置,我们建议在安装后设置为禁止。 那么,如果确实需要调整某一列的顺序,我们是怎么操作的呢? 下面,我们就要演示一下怎么取消这种限制。...当然,通过取消限制的演示,相信大家也知道了怎么添加限制了。...需求及问题描述 1)测试表 Test001 (2)更新前 (3)例如,需求为调整 SN5 和SN4的序列 点击保存时报错 修改数据库表结构时提示【不允许保存更改。...您所做的更改要求删除并重新创建以下表。您对无法重新创建的标进行了更改或者启用了“阻止保存要求重新创建表的更改"选项。】

    4.3K20

    【说站】excel筛选两列数据中的重复数据并排序

    的“条件格式”这个功能来筛选对比两列数据中心的重复值,并将两列数据中的相同、重复的数据按规则进行排序方便选择,甚至是删除。...比如上图的F、G两列数据,我们肉眼观察的话两列数据有好几个相同的数据,如果要将这两列数据中重复的数据筛选出来的话,我们可以进行如下操作: 第一步、选择重复值 1、将这两列数据选中,用鼠标框选即可; 2...,我这里按照默认设置); 4、上一步设置完,点击确定,我们可以看到我们的数据变成如下图所示: 红色显示部分就表示两列数据重复的几个数据。...第二步、将重复值进行排序 经过上面的步骤,我们将两列数据的重复值选出来了,但数据的排列顺序有点乱,我们可以做如下设置: 1、选中F列,然后点击菜单栏的“排序”》“自定义排序”,选择“以当前选定区域排序”...2、选中G列,做上述同样的排序设置,最后排序好的结果如下图: 经过上面的几个步骤,我们可以看到本来杂乱无章的两列数据现在就一目了然了,两列数据中的重复数据进行了颜色区分排列到了上面,不相同的数据也按照一定的顺序进行了排列

    10.3K20

    C++中自定义结构体或类作为关联容器的键

    概述 STL中像set和map这样的容器是通过红黑树来实现的,插入到容器中的对象是顺序存放的,采用这样的方式是非常便于查找的,查找效率能够达到O(log n)。...所以如果有查找数据的需求,可以采用set或者map。 但是我们自定义的结构体或者类,无法对其比较大小,在放入到容器中的时候,就无法正常编译通过,这是set/map容器的规范决定的。...要将自定义的结构体或者类存入到set/map容器,就需要定义一个排序的规则,使其可以比较大小。...最简单的办法就是在结构体或者类中加入一个重载小于号的成员函数,这样在存数据进入set/map中时,就可以根据其规则排序。 2....<< endl; } else { cout << "可以找到点" << endl; } } } 其中的关键就是在点的结构体中重载了

    2.2K20
    领券