一般都认为一条数据在表中通过主键字段来唯一确定,但是有时候表中并不存在主键,但是重复数据插入也会报错,查看表结构发现,通过建立唯一键值也可以达到之一目的,但是最近有遇到数据库中没有唯一键、主键,重复数据插入也会报错,查询后发现存在唯一索引,也达到了数据唯一的目的
(1)主键约束和唯一键约束均会隐式创建同名的唯一索引,当主键约束或者唯一键约束失效时,隐式创建的唯一索引会被删除;
(2)主键约束要求列值非空,而唯一键约束和唯一索引不要求列值非空;
(3)相同字段序列不允许重复创建索引;
(4)表的主键最多只有一个,唯一键和索引可以有多个。
oracle 中数据库 和实例。数据库是指数据存储的物理文件,实例是指数据文件和数据库进程。
表空间 类似于存储仓库,先建用户,再建表,表属于用户,表在表空间中,同一表名可以存在于不同用户下,并存在于一个表空间。A 用户下的表要让B用户查到,只需grant select ON b.表名
- 外键
外键的存在就是为了保持数据完整的,比如存在订单表、订单详情表,我们在订单表和订单详情表通过订单iD关联,在订单详情表中,id就是外键,如果单独在详情表插入一条信息,程序报错,需要先添加订单表信息,再添加订单详情信息。同理我们删除订单信息时,设置联动后订单详情表中的数据也会自动删除。