51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1486|回复: 0
打印 上一主题 下一主题

[原创] 自己的东东2

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2010-4-26 19:04:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
        相同点:都能够确定唯一性
唯一约束冲突
SQL> insert into emp(empid,emp_name,deptno,salary) values(1,'zhangsan',10,0);
已创建 1 行。
SQL> insert into emp(empid,emp_name,deptno,salary) values(2,'zhangsan',20,0);
insert into emp(empid,emp_name,deptno,salary) values(2,'zhangsan',20,0)
*
ERROR 位于第 1 行:
ORA-00001: 违反唯一约束条件 (SCOTT.UK_EMP)

主键冲突
SQL> insert into emp(empid,emp_name,deptno,salary) values(1,'zhangsan',10,0);
已创建 1 行。
SQL> insert into emp(empid,emp_name,deptno,salary) values(1,'lisi',20,0);
insert into emp(empid,emp_name,deptno,salary) values(1,'lisi',20,0)
*
ERROR 位于第 1 行:
ORA-00001: 违反唯一约束条件 (SCOTT.PK_EMP)
SQL> rollback;
回退已完成。

        不同点:主键约束不允许空,但唯一约束可以为空,
            每张表最多只有一个主键,但可以具有多个唯一约束(此处不做验证)
主键为空:
SQL> insert into emp(empid,emp_name,deptno,salary) values('','张三',20,0);
insert into emp(empid,emp_name,deptno,salary) values('','张三',20,0)
*
ERROR 位于第 1 行:
唯一约束为空:
ORA-01400: 无法将 NULL 插入 ("SCOTT"."EMP"."EMPID")
SQL> insert into emp(empid,emp_name,deptno,salary) values(1,'',20,0);
已创建 1 行。
SQL> insert into emp(empid,emp_name,deptno,salary) values(2,'',20,0);
已创建 1 行。
SQL> insert into emp(empid,emp_name,deptno,salary) values(3,'',20,0);
已创建 1 行。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-9-21 11:11 , Processed in 0.084005 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表