primary key与unique的区别 及 insert方法的一些说明注意

18 篇文章 0 订阅
7 篇文章 0 订阅

定义了 UNIQUE 约束的字段中不能包含重复值,可以为一个或多个字段定义 UNIQUE 约束。因此,UNIQUE 即可以在字段级也可以在表级定义, 在UNIQUED 约束的字段上可以包含空值。Oracle自动会为具有 PRIMARY KEY 约束的字段(主码字段)建立一个唯一索引和一个NOT NULL约束,定义PRIMARY KEY约束时可以为它的索引; 

UNIQUED 可空,可以在一个表里的一个或多个字段定义;PRIMARY KEY 不可空不可重复,在一个表里可以定义联合主键;

简单的说,primary key = unique +  not null 

unique 就是唯一,当你需要限定你的某个表字段每个值都唯一,没有重复值时使用。比如说,如果你有一个person 表,并且表中有个身份证的column,那么你就可以指定该字段为unique。 从技术的角度来看,Primary Key和Unique Key有很多相似之处。但还是有以下区别: 

一、作为Primary Key的域/域组不能为null,而Unique Key可以。 

二、在一个表中只能有一个Primary Key,而多个Unique Key可以同时存在。 

更大的区别在逻辑设计上。Primary Key一般在逻辑设计中用作记录标识,这也是设置Primary Key的本来用意,而Unique Key只是为了保证域/域组的唯一性。 

oracle的constraint中有两种约束,都是对列的唯一性限制――unique与primary key,但其中是有区别的:

1、unique key要求列唯一,但不包括null字段,也就是约束的列可以为空且仅要求列中的值除null之外不重复即可;

2、primary key也要求列唯一,同时又限制字段的值不能为null,相当于Primary Key=unique + not null。 

创建一个primary key和unique key都会相应的创建一个unique index。

0primary key的语法:alter table table name add constraint key name primary key( columns); 

unique key的语法:alter table table name add constraint key name unique( columns); 


一个表只能有一个主键,但是可以有好多个UNIQUE,而且UNIQUE可以为NULL值,如员工的电话号码一般就用UNIQUE,因为电话号码肯定是唯一的,但是有的员工可能没有电话。

主键肯定是唯一的,但唯一的不一定是主键;

不要总把UNIQUE索引和UNIQUE约束混为一谈

1、primary key = unique + not null

2、唯一约束和主键一样都是约束的范畴,而且都可以作为外键的参考,不同的是,一张表只能有一个主键

3、主键和唯一约束的创建需要依靠索引,如果在创建主键或唯一约束的时候没有已经建好的索引可以使用的话,Oracle会自动建立一个唯一的索引。


原文地址: 点击打开链接


如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE;如果不会导致唯一值列重复的问题,则插入新行。例如,如果列a被定义为UNIQUE,并且包含值1,则以下两个语句具有相同的效果: 

[sql]  view plain  copy
  1. INSERT INTO TABLE (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=c+1;  
[sql]  view plain  copy
  1. UPDATE TABLE SET c=c+1 WHERE a=1;  
如果行作为新记录被插入,则受影响行的值为1;如果原有的记录被更新,则受影响行的值为2。

如果你想了解更多关于INSERT INTO .. ON DUPLICATE KEY的功能说明,详见MySQL参考文档:13.2.4. INSERT语法

现在问题来了,如果INSERT多行记录, ON DUPLICATE KEY UPDATE后面字段的值怎么指定?要知道一条INSERT语句中只能有一个ON DUPLICATE KEY UPDATE,到底他会更新一行记录,还是更新所有需要更新的行。这个问题困扰了我很久了,其实使用VALUES()函数一切问题都解决了。

 举个例子,字段a被定义为UNIQUE,并且原数据库表table中已存在记录(2,2,9)和(3,2,1),如果插入记录的a值与原有记录重复,则更新原有记录,否则插入新行:

[sql]  view plain  copy
  1. INSERT INTO TABLE (a,b,c) VALUES  
  2. (1,2,3),  
  3. (2,5,7),  
  4. (3,3,6),  
  5. (4,8,2),  
  6. ON DUPLICATE KEY UPDATE b=VALUES(b);   
以上SQL语句的执行,发现(2,5,7)中的a与原有记录(2,2,9)发生唯一值冲突,则执行ON DUPLICATE KEY UPDATE,将原有记录(2,2,9)更新成(2,5,9),将(3,2,1)更新成(3,3,1),插入新记录(1,2,3)和(4,8,2)

注意:ON DUPLICATE KEY UPDATE只是MySQL的特有语法,并不是SQL标准语法!

原文地址:点击打开链接


报错 : UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-4: ordinal not in range(128)


原文: 点击打开链接


报错 : Caused by : adnroid.database.sqlite.SQLiteConstraintExcepton: UNIQUE consitraint failed : ColorBlock.id(code 1555)


数据库中我们经常会有这种需求,插入时,某条记录不存在则插入,存在则更新。或更新时,某条记录存在则更新,不存在则插入。比如: 
人员信息数据库,某个身份证若已经存在,重复插入则更新,否则新增记录。 
在sqlite中我们可以使用replace into实现.


原文: 点击打开链接 类似的 点击打开链接






  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
unique index和unique key是在数据库中用于确保数据表中某一列或一组列的唯一性的约束。它们的作用是防止重复的数据出现在这些列中。 区别在于,unique index是一种普通索引,它只是确保列的唯一性,不会对数据表的完整性产生其他约束。而unique key则更多地指的是逻辑上的事,它可以用来定义主键、外键等约束,同时也会确保列的唯一性。 需要注意的是,unique index和unique key可能会有不同的语法表示,但它们的目的都是为了保证数据表中某一列或一组列的唯一性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Mysql中keyprimary keyunique key 与index区别](https://blog.csdn.net/weixin_43946245/article/details/100993359)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [key,unique index,联合索引](https://blog.csdn.net/Irean_Lau/article/details/52175765)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值