oracle 主键、唯一键值、唯一索引关系

一般都认为一条数据在表中通过主键字段来唯一确定,但是有时候表中并不存在主键,但是重复数据插入也会报错,查看表结构发现,通过建立唯一键值也可以达到之一目的,但是最近有遇到数据库中没有唯一键、主键,重复数据插入也会报错,查询后发现存在唯一索引,也达到了数据唯一的目的
(1)主键约束和唯一键约束均会隐式创建同名的唯一索引,当主键约束或者唯一键约束失效时,隐式创建的唯一索引会被删除;

(2)主键约束要求列值非空,而唯一键约束和唯一索引不要求列值非空;

(3)相同字段序列不允许重复创建索引;
(4)表的主键最多只有一个,唯一键和索引可以有多个。

oracle 中数据库 和实例。数据库是指数据存储的物理文件,实例是指数据文件和数据库进程。
表空间 类似于存储仓库,先建用户,再建表,表属于用户,表在表空间中,同一表名可以存在于不同用户下,并存在于一个表空间。A 用户下的表要让B用户查到,只需grant select ON b.表名

  • 外键
    外键的存在就是为了保持数据完整的,比如存在订单表、订单详情表,我们在订单表和订单详情表通过订单iD关联,在订单详情表中,id就是外键,如果单独在详情表插入一条信息,程序报错,需要先添加订单表信息,再添加订单详情信息。同理我们删除订单信息时,设置联动后订单详情表中的数据也会自动删除。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值