数据库中创建unique唯一约束
admin
2023-06-10 21:43:32
0

   最近项目中的需求,确定唯一一条数据,原来貌似碰到过,忘记了,现在记录一下。实现唯一约束还可以不是主键的unique。


   oracle中的unique约束是用来保证表中的某一类,或者表中的某一类组合起来不重复的一种手段。我们在可以在创建表时或者创建好后通过修改表的方式来创建oracle中的unique约束。

  下面是一些创建unique约束的例子:

  create table unique_test

  (id number,

  fname varchar2(20),

  lname varchar2(20),

  address varchar2(100),

  email varchar2(40),

  constraint name_unique unique(fname,lname))

  在这里我们建立了一个表unique_test,并将其中的fname和lname组合起来建立了一个唯一约束。

  我们也还可以在表创建完成后手动的通过修改表的方式来增加约束,例如:

  alter table unique_test

  add constraint email_unique unique(email);

  下面我们来往表里面插入数据,

  insert into unique_test(id,fname,lname) values(1,’德华’,'刘’)

  这一行可以正常的被插入

  因为我们在建立表时曾把fname和lname联合起来作为一个约束,因为如果我们希望再次插入刘德华,

  insert into unique_test(id,fname,lname) values(2,’德华’,'刘’)

  是会出现如下错误的:

  ORA-00001: 违反唯一约束条件 (SYS.NAME_UNIQUE)

  但我们如果改为如下值:

  insert into unique_test(id,fname,lname) values(2,’学友’,'张’);

  又可以正常插入了。

  有些朋友可能会有疑问,我们不是为email也建立的一个唯一约束吗?为什么这两行数据都没有为email列赋值,也就是或两行的email列都是空值,而插入也成功了呢?

  这是因为一个空值(null)的含义是该列当前的状态是不存在,他永远不可能会与另外一个空值相等。所以也就不存在违反唯一约束之说了


相关内容

热门资讯

实名购药、严禁AI替代审方,《... 网上买药便捷高效,已经成为不少人日常购药的首选方式。如何保障公众网上购药安全,成为我国相关监管部门关...
日韩真麻了:零食袋褪色,尿布、... 【文/观察者网 齐倩】美媒注意到,除中国之外,亚洲多国正因石脑油短缺而陷入困境。石脑油是一种石油衍生...
企业强推AI提效遇反效果:AI... IT之家 5 月 24 日消息,众多科技企业督促员工使用人工智能工具提升工作效率,但这项举措已然开始...
为保中国市场,卡塔尔拼了:悄悄... 【文/观察者网 齐倩】根据船舶跟踪数据,近日,三艘装载液化天然气(LNG)的运输船似乎已穿越霍尔木兹...
美国人情绪达70年来最低点:股... 【文/观察者网 齐倩】美国社会出现罕见“冰火两重天”景象:股市火爆,但美国民众的情绪非常糟糕。这与以...
三星罢工风波影响外溢?台积电绩... 财联社5月25日讯(编辑 马兰)韩国半导体巨头三星电子的罢工风波虽暂告一段落,但其余波却远未平息。综...
胜率直逼人类大师!这套Agen... 新智元报道 【新智元导读】没有信息泄漏的专业术数题库面前,Claude、GPT等主流模型集体「翻车...
30天内全面恢复霍尔木兹通行?... 据新华社消息,美媒5月24日报道称,美国和伊朗已就一份谅解备忘录框架达成一致,一旦签署,将在30天内...
刚刚,Ilya又发神图「思考者... 新智元报道 【新智元导读】「什么都没说,却什么都说了。」Ilya用一幅Die Shot上的《思考者...
【场面】讲述“看见”的故事,开... 来源:滚动播报 (来源:上观新闻) 2026年5月22日,光学巨头蔡司在上海举办未来产业创新峰会,...