Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2154254
  • 博文数量: 157
  • 博客积分: 10047
  • 博客等级: 上将
  • 技术积分: 6757
  • 用 户 组: 普通用户
  • 注册时间: 2005-05-19 11:38
文章分类

全部博文(157)

文章存档

2011年(16)

2010年(50)

2009年(42)

2008年(49)

我的朋友

分类: Oracle

2008-05-13 21:00:22

在后台中开发了一个存储过程用到merge into,主要是根据主键值来查看目标表中是否有该主键值,如果有进行更新,否则插入,然而在测试过程中经常出现ORA-00001 主键冲突。
前端开发人员口口声声说传入的数据不会有重复值,怀疑数据库的问题。我相信Oracle不会有这样的bug。
索性我在后台演示出现该错误的方法。
 
1、创建测试表
create table T_TEST
(                 
  A CHAR(1),      
  B NUMBER        
)                 
2、创建测试存储过程
create or replace procedure test(i_num in number) is                                 
begin                                                               
  MERGE INTO t_test t                                               
  USING (SELECT '1' a, ROWNUM b FROM DUAL CONNECT BY ROWNUM <= i_num) TA
  ON (t.a = TA.a)                                                   
  WHEN MATCHED THEN                                                 
    UPDATE SET T.b = t.b + TA.b                                     
  WHEN NOT MATCHED THEN                                             
    INSERT VALUES (TA.a, TA.b);                                     
   commit;                                                                 
end test;
3、执行存储过程test
SQL> exec test(12);                                                                               
                                      
PL/SQL procedure successfully completed
                                      
SQL> select * from t_test;            
                                      
A          B                          
- ----------                          
1         12                          
1         11                          
1         10                          
1          9                          
1          8                          
1          7                          
1          6                          
1          5                          
1          4                          
1          3                          
1          2                          
1          1                          
                                      
12 rows selected                      
                                      
SQL>
4、清空t_test
SQL> truncate table t_test;                        
                          
Table truncated           
                          
SQL>             
5、添加主键
SQL> ALTER TABLE T_TEST ADD CONSTRAINT PK_T_TEST PRIMARY KEY (A)  USING INDEX;        
                                                                             
Table altered
6、在t_test中添加一行数据                                                            
 SQL> exec test(1);                        
                                           
 PL/SQL procedure successfully completed   
                                           
 SQL> select * from t_test;                
                                           
 A          B                              
 - ----------                              
 1          1           
7、此时尝试再次添加多行数据,此时会出现错误ORA-30926,原因是在Using选项后面中a有多个重复值
                                           
 SQL> exec test(10);                       
                                           
 begin test(10); end;                      
                                           
 ORA-30926: 无法在源表中获得一组稳定的行   
 ORA-06512: 在 "TEST.TEST", line 3         
 ORA-06512: 在 line 1                      
                                           
 SQL>        
 8、清空t_test
 SQL> truncate table t_test;                                          
                                           
 Table truncated                            
 9、尝试添加多行a值相同的数据,提示主键冲突                                          
 SQL> exec test(10);                        
                                           
 begin test(10); end;                       
                                           
 ORA-00001: 违反唯一约束条件 (TEST.PK_T_TEST)
 ORA-06512: 在 "TEST.TEST", line 3          
 ORA-06512: 在 line 1                       
                                           
 SQL>
 
由此可以证明还是由于传入的数据有重复值导致的。
具体得在程序中继续跟踪,好让他们心服口服。                                       
阅读(4908) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~