oracle 非空 唯一索引,sql – 如何在Oracle中创建唯一的索引,但忽略null?

本文介绍如何使用Oracle SQL中的NVL2函数来创建一个确保唯一性的索引,即使是在部分字段可能为空的情况下也能正确工作。通过具体示例展示了如何避免因重复插入相同空值而导致的约束冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们可以使用基于函数的索引来实现。以下使用NVL2(),如您所知,如果表达式不为空,则返回一个值,如果为空,则返回不同的值。您可以使用CASE()。

SQL> create table blah (name varchar2(10), email varchar2(20))

2 /

Table created.

SQL> create unique index blah_uidx on blah

2 (nvl2(email, name, null), nvl2(name, email, null))

3 /

Index created.

SQL> insert into blah values ('APC', null)

2 /

1 row created.

SQL> insert into blah values ('APC', null)

2 /

1 row created.

SQL> insert into blah values (null, 'apc@example.com')

2 /

1 row created.

SQL> insert into blah values (null, 'apc@example.com')

2 /

1 row created.

SQL> insert into blah values ('APC', 'apc@example.com')

2 /

1 row created.

SQL> insert into blah values ('APC', 'apc@example.com')

2 /

insert into blah values ('APC', 'apc@example.com')

*

ERROR at line 1:

ORA-00001: unique constraint (APC.BLAH_UIDX) violated

SQL>

编辑

因为在您的方案名称中将始终填充您将只需要这样的索引:

SQL> create unique index blah_uidx on blah

2 (nvl2(email, name, null), email)

3 /

Index created.

SQL>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值