问题描述
嗨,
在下面的文档中,我发现此文本 “oracle在评估解码函数时认为两个空值相等。有关语法和其他信息,请参阅DECODE。
如果两个空值出现在复合键中,Oracle也认为它们相等。也就是说,如果键的所有非null组件都相等,则Oracle会考虑相同的两个包含null的复合键。'
https://docs.oracle.com/cd/B19306_01/server.102/b14200/sql_elements005.htm
我知道解码功能,但我不熟悉这个概念 “复合键”,我用google搜索了它,但找不到任何来源。
如果可能的话,也会解释这个概念。
提前给你坦克。
在下面的文档中,我发现此文本 “oracle在评估解码函数时认为两个空值相等。有关语法和其他信息,请参阅DECODE。
如果两个空值出现在复合键中,Oracle也认为它们相等。也就是说,如果键的所有非null组件都相等,则Oracle会考虑相同的两个包含null的复合键。'
https://docs.oracle.com/cd/B19306_01/server.102/b14200/sql_elements005.htm
我知道解码功能,但我不熟悉这个概念 “复合键”,我用google搜索了它,但找不到任何来源。
如果可能的话,也会解释这个概念。
提前给你坦克。
专家解答
复合键是包含一个以上属性 (列) 的键。在这种情况下,唯一性由所有非空值定义,因此从这个角度来看,多个空值可以被视为 “等效”。
例如
例如
SQL> create table t ( x int, y int, z int ); Table created. SQL> SQL> create unique index ix on t ( x,y); Index created. SQL> SQL> insert into t values (1,null,10); 1 row created. SQL> insert into t values (1,null,20); insert into t values (1,null,20) * ERROR at line 1: ORA-00001: unique constraint (MCDONAC.IX) violated复制
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。