时间:2021-05-24
1、建表语句:
CREATE TABLE `employees` ( `emp_no` int(11) NOT NULL, `birth_date` date NOT NULL, `first_name` varchar(14) NOT NULL, `last_name` varchar(16) NOT NULL, `gender` char(1) NOT NULL, `hire_date` date NOT NULL, PRIMARY KEY (`emp_no`), UNIQUE KEY `idxunique_first_name_gender` (`first_name`,`gender`), UNIQUE KEY `uniq_idx_firstname` (`first_name`,`gender`)) ENGINE=InnoDB DEFAULT CHARSET=utf82、添加unique key:
-- 添加unique索引alter table employees add constraint idxunique_first_name_gender unique(first_name, gender);3、查询测试语句:
-- 包含索引所有字段,且顺序和索引一致select * from employees where first_name='Chirstian' and gender='M';-- key列值:idxunique_first_name_gender-- 包含索引所有字段,但顺序和索引不一致select * from employees where gender='M' and first_name='Chirstian';-- key列值:idxunique_first_name_gender-- 包含索引第一个字段select * from employees where first_name='Chirstian';-- key列值:idxunique_first_name_gender-- 包含索引的非第一个字段select * from employees where gender='M';-- key列值:NULL4、在查询时,如果where条件里面只有unique key里面的列(部分或者全部)且列值类型为const。如果要使用unique key,where里面必须得有建立unique key时的第一列,其他列随意。
一个与mysql unique key相关的问题
xxx_tab的user_id是unique key, 来看看伪代码:
get user_id=10000 from xxx_tab;if exist { return ok}ret = insert user_id=10000if ret ok { return ok}return not_ok问题: 为什么最后结果是not_ok ?
提示: 分布式影响
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
有这样的一个问题mysql查询使用mysql中left(right)join筛选条件在on与where查询出的数据是否有差异。可能只看着两个关键字看不出任何的问
mysql唯一索引UNIQUE一般用于不重复数据字段了我们经常会在数据表中的id设置为唯一索引UNIQUE,下面我来介绍如何在mysql中使用唯一索引UNIQU
PHP查询MySQL大量数据的内存占用分析这篇文章主要是从原理,手册和源码分析在PHP中查询MySQL返回大量结果时,内存占用的问题,同时对使用MySQLCAP
当unique列在一个UNIQUE键上插入包含重复值的记录时,我们可以控制MySQL如何处理这种情况:使用IGNORE关键字或者ONDUPLICATEKEYUP
这儿记录一些在使用MySQL的过程中遇到的问题以及相应的解决办法。sql_mode=only_full_group_by引起groupby查询报错问题MySQL