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

在Oracle数据库中外创建

在Oracle数据库中,外是强制实施参照完整性的一种方式,使用外就意味着一个表中的值在另一个表中也必须出现。 被引用的表称为父表,而带有外的表称为子表。子表中的外通常会引用父表中的主键。...外的创建 1、使用CREATE TABLE语句创建 使用CREATE TABLE语句创建外的语法是: CREATE TABLE table_name ( column1 datatype null...然后,在products表上创建了一个名为fk_supplier的外,该表根据supplier_id字段引用supplier表。...2、使用ALTER TABLE语句创建 在ALTER TABLE语句中创建外的语法是: ALTER TABLE table_name ADD CONSTRAINT constraint_name...我们也可以创建一个具有多个字段的外,如下例所示: ALTER TABLE products ADD CONSTRAINT fk_supplier FOREIGN KEY (supplier_id,

86320

mysql使用基础 sql语句与数据完整性(二)

: mysql>SET character_set_client=gbk; 显示时乱码: mysql>SET character_set_results=gbk; ②使用insert语句向表中插入记录...>INSERT INTO user VALUES (2,'Jack','1','1987-09-07','2013-04-12','CEO',10000.00,'hand'); ③使用update语句更改表中记录...DELETE FROM user; 使用TRUNCATE删除表中记录(摧毁整张表,然后重建表结构): mysql>TRUNCATE user; 三、数据完整性 数据完整性分为四类:实体完整性(Entity...①实体完整性: 规定表中的一行在表中是唯一的实体,一般是通过定义主键的形式来实现的。实体完整性要求每一个表中的主键字段都不能为空或者重复的值。实体完整性指表中行的完整性。...与具体业务有关 ③参照完整性(多表设计) 当更新、删除、插入一个表中的数据时,通过参照引用相互关联的另一个表中的数据,来检查对表的数据操作是否正确,简单的说就是表间主键外的关系。

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

    MySQL学习之路:数据的完整性-外约束

    数据的完整性 数据完整性是指数据的准确性和逻辑一致性,用来防止数据库中存在不符合语义、无效数据或错误数据等。...MySQL中,数据完整性通常使用约束来实现,本任务主要的约束包括PRIMARY KEY约束、NOT NULL约束、DEFAULT约束、UNIQUE约束、CHECK约束和FOREIGH KEY约束。...id 3 gcode varchar(50) 否 商品编号 4 gname varchar (200) 否 商品名称 5 gprice decimal(20,2) 商品价格 使用SQL语句添加外约束...外约束实现了表间的引用完整性,当主表中被引用列的值发生变化时,为了保证表间数据的一致性,从表的中与该值相关的信息也应该相应更新,这就是外约束的级联更新和删除。...NO ACTION:不进行任何操作 RESTRICT:拒绝主表更新或修改外的关联列。 删除约束 使用DROP TABLE语句删除表时,表中所有的约束也随之被删除。

    28020

    MySQL 系列】MySQL 语句篇_DCL 语句

    MySQL 访问权限控制系统的用户界面由几条 SQL 语句组成,如 CREATE USER、GRANT 和 REVOKE。 在服务器内部,MySQL 将权限信息存储在 mysql 系统库的权限表中。...2、MySQL 中库表的 DQL 语句详解 2.1、MySQL 服务器登录 启动 MySQL 服务后,可以通过 mysql 命令来登录 MySQL 服务器,命令如下: mysql –h hostname...登录 MySQL 服务器以后即可执行这个 SQL 语句,然后退出 MySQL 服务器 举例: mysql -u root -p -h localhost -P 3306 mysql -e "select...在 MySQL 中,您可以使用 CREATE USER 语句在数据库服务器中创建一个新用户。...References:在创建外约束时,该权限需要用户具有父表的 References 权限。 Reload:该权限允许用户使用 FLUSH 语句

    16410

    MySQL 系列】MySQL 语句篇_DML 语句

    1、MySQL 中的 DQL 语句 1.1、数据查询语言–DML DML(Data Manipulation Language),即数据操作语言,用于操作数据库对象中所包含的数据。...[WHERE clause]; 2、MySQL 中 的 DML 语句详解 2.1、DML语句:INSERT 在 MySQL 中,INSERT 语句用于将一行或者多行数据插入到数据表的指定列中。...2.2.3、使用 UPDATE 修饰符 在 MySQL 中, UPDATE 语句支持 2 个修饰符: LOW_PRIORITY: 如果你指定了 LOW_PRIORITY 修饰符,MySQL 服务器将延迟执行...如下: TRUNCATE actor_copy; 2.3.4、使用 DELETE 表别名删除 在早期的 MySQL 版本中, 单表删除 DELETE 语句不支持为表设置别名。...2.3.6、使用 DELETE 修饰符 在 MySQL 中, DELETE 语句支持 3 个修饰符: LOW_PRIORITY: 如果你指定了 LOW_PRIORITY 修饰符,MySQL 服务器将延迟执行

    17810

    解决django框架model中外不落实到数据库问题

    在外字段的参数中添加db_constraint=False即可,数据库中没有外关系,代码中依然可以按照正常外方式使用。...db_constraint=False) class Room(models.Model): status = models.IntegerField(default=1) 补充知识:Django不通过外查询多对多的数据...,数据库表设计不使用外 终于解决了 如何没有通过外查询多对多的数据,多对一数据 意义: 使用外,高并发的程序中会产生锁表,影响性能。...为了未来的数据库扩展,数据库设计时考虑使用外,但在实际数据库设计时,将外的实现放在逻辑层控制。 全部的表都是单表 解决的办法是通过SerializerMethodField自定义字段来实现。...以上这篇解决django框架model中外不落实到数据库问题就是小编分享给大家的全部内容了,希望能给大家一个参考。

    1.4K10

    Mysql中外连接,内连接,左连接,右连接的区别

    可能主要就是下面这几种方式: 直接通过where语句将重叠的字段进行匹配就比如下面这种 select * from tablea,tableb where tablea.aid=tableb.bid;...tablea.aid=tableb.bid; select * from tablea INNER JOIN tableb on tablea.aid=tableb.bid; 可能第一种通过where语句查询...显然这里是以 tableb 的数据为基准的 看完这两个例子,想必大家也能够自己分析出来了,显然永远是左表的数据是完整的,右表中只会查询出与左表匹配的数据,如果不匹配就不显示,显示为空.整个过程都是以左表为基准的...这里我们通过与上面外连接的对比分析之后就可以看出来,内连接整个更加能够体现数据的完整性,上图我们可以看出内连接只会显示所有产生连接的数据,那些不匹配的数据,不管是左表中的还是右表中的....通过上面几个例子.相信大家就能够更加理解MYSQL中这几种连接的意义了. 都看到这里了,如果觉得对你有帮助的话,可以关注博主的公众号,新人up需要你的支持.

    4.5K20

    表——完整约束性规则(

    一 介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性 主要分为: primary key (PK) 标识该字段为该表的主键,可以唯一的标识记录 foreign...key (FK) 标识该字段为该表的外 not null 标识该字段不能为空 unique key (UK) 标识该字段的值是唯一的 auto_increment 标识该字段的值自动增长...是否是key 主键 primary key 外 foreign key 索引 (index,unique...)...并且被关联的字段必须唯一 create table department( id int primary key, name varchar(20) not null )engine=innodb; #dpt_id外,...int default 1, customer_id int unique, #该字段一定要是唯一的 foreign key(customer_id) references customer(id) #外的字段一定要保证

    2.4K70

    mysql分区语句

    ( MONTH(signed) ) PARTITIONS 12; 将分区表从12个分区变为8个分区 ALTER TABLE clients COALESCE PARTITION 4; 同样的有以下的语句关于...provided that the following statements are true: 要满足以下的条件: 1:PT是已经分区表,nt不是临时表 2:两张表的表结构必须是一模一样的 3:nt不能有外约束...,也不能有关于其他表的外约束. 4:nt表中的数据没有分区P以外的数据.WITHOUT VALIDATION指定的时候这条就可以忽视调 另外很重要的一点就是想要拥有EXCHANGE的权限的话必须对全表有...provided that the following statements are true: 要满足以下的条件: 1:PT是已经分区表,nt不是临时表 2:两张表的表结构必须是一模一样的 3:nt不能有外约束...,也不能有关于其他表的外约束. 4:nt表中的数据没有分区P以外的数据.WITHOUT VALIDATION指定的时候这条就可以忽视调 另外很重要的一点就是想要拥有EXCHANGE的权限的话必须对全表有

    12.3K10

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券