mysql唯一索引和unique

最近遇到一个问题:高并发环境下,如何避免一张表里的某些列不要重复。

我这样回答的(被“高并发”给骗了,傻傻地往复杂里想):
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;

试一下

首先建表:

测试unique的作用:

测试动态修改唯一索引:
1. 删除
删除
2. 增加
add

primary key和唯一索引的区别

有人说主键是特殊的索引,只不过它不允许为空,并且在一张表里只能声明一组列为主键,主键可以被外键引用,mysql等数据库一般都自动给主键列建立索引来优化查询,比如使用explain来看一下:

注意看里面的”possible_keys”这一列,它是用了”PRIMARY”这一个索引来查找的!
参考:http://blog.csdn.net/haifu_xu/article/details/16864933

而唯一索引可以对多个列都做,并且它是可以为空的,它虽然叫做索引,但是它主要是用来防止某些列的重复的,而不是专门用来查找的,所以和普通的索引的效率差别????(等我知道了再解释~)

最后附上这次实验的代码:

// 建表
create table Test (
    id INT NOT NULL,
    name VARCHAR(30) unique,
    phoneNumber VARCHAR(20),
    password VARCHAR(32),
    primary key(id),
    unique key pn (phoneNumber)
);

// 测试建表方法的unique效果
insert into Test values(1, 'name', '123456', 'psw');
insert into Test values(2, 'name', '654321', 'psw2');


// 测试动态修改方法的unique效果
ALTER TABLE Test DROP INDEX name;
insert into Test values(2, 'name', '654321', 'psw2');
select * from Test;
insert into Test values(3, 'name', '654321', 'psw2');


// 测试动态修改方法的unique效果
select * from Test;
CREATE UNIQUE INDEX `psw` on Test(password);
insert into Test values(3, 'name', '233', 'psw2');


// 查询mysql执行按主键select时的表现
explain select * from Test where id=1;
  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值