最近遇到一个问题:高并发环境下,如何避免一张表里的某些列不要重复。
我这样回答的(被“高并发”给骗了,傻傻地往复杂里想):
1. 查找和插入这两个操作做成一个事务,对整张表加锁。。。是不是很low的想法?
2. 那就允许临时的不一致性,不管三七二十一,随便插,在查询、修改、删除的时候将多余的行删掉就好了,即保证最终一致性即可。。。好像效率高了一点,但是好麻烦啊。。。
面试官跟我说,知不知道“唯一索引”,突然间就蒙了(⊙o⊙)…
其实就是unique啦,这也从侧面表现出自己这方面的基础不够扎实,居然没有第一时间想到最简单的做法,sql标准本身就是支持这样一个需求的!
具体怎么做呢?
可以在声明表的时候就加入这样一个约束(下面是mysql的语法):
create table Test ( id INT NOT NULL, name VARCHAR(30) unique, phoneNumber VARCHAR(20), password VARCHAR(32), primary key(id), unique key pn (phoneNumber) );
也可以在建表后增加或删除索引:
CREATE UNIQUE INDEX pw on Test(password);
ALTER TABLE Test DROP INDEX pn;
试一下
首先建表: