首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL字符串索引

MySQL是支持前缀索引的,前缀索引的优势就是占用的空间小,这同时带来的损失是,可能会增加额外的记录扫描次数。...如果要使用的是邮箱登录,所以代码中一定会有这种类似的语句 select f1, f2 from tableName where email='xxx'; 如果email这个字段上没有索引的话,那这些语句就只能做全表扫描 MySQL...是支持前缀索引的,可以定义字符串的一部分作为索引。...默认地,如果你创建索引的语句不指定前缀长度,那么索引就会包含整个字符串。...有以下2中方式 就是使用倒序存储,比如身份证倒序,查询的时候再用函数转一下 以及使用hash字段,在表上创建一个整数字段,来保存身份证的校验码,同时在这个字段上索引 这两种方式对比区别 从占用的额外空间来看

2.1K71

怎么字符串索引

怎么字符串索引 比如说,要给邮箱这样的字段索引,这样长字符串索引会有什么样的问题? 前缀索引,如果长度长,会浪费大量的空间,同时增加额外的查询成本。...MySQL 支持前缀索引,可以定义字符串的一部分作为索引,创建索引的语句不指定前缀长度,那么索引就会包含整个字符串。...mysql> alter table SUser add index index1(email); mysql> alter table SUser add index index2(email(6))...当要给字符串创建前缀索引时,如何确定使用多长的前缀?...还有没有其他方式帮助字符串建立索引 比如能够确定业务需求里面只有按照身份证等值查询的需求,需要给身份证索引,有没有什么办法,占用更小空间,也能达到相同的查询效率。

1.8K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL实战第十一讲-怎么字符串字段索引?

    现在,几乎所有的系统都支持邮箱登录,如何在邮箱这样的字段上建立合理的索引,是我们今天要讨论的问题。...同时,MySQL 是支持前缀索引的,也就是说,你可以定义字符串的一部分作为索引。默认地,如果你创建索引的语句不指定前缀长度,那么索引就会包含整个字符串。...小结 在今天这篇文章中,我跟你聊了聊字符串字段创建索引的场景。我们来回顾一下,你可以使用的方式有: 1. 直接创建完整索引,这样可能比较占用空间; 2. ...因为维护的只是一个学校的,因此前面 6 位(其中,前三位是所在城市编号、第四到第六位是学校编号)其实是固定的,邮箱后缀都是 @gamil.com,因此可以只存入学年份顺序编号,它们的长度是 9 位。...其实这个就是一种 hash,只是它用了最简单的转换规则:字符串转数字的规则,而刚好我们设定的这个背景,可以保证这个转换后结果的唯一性。

    2.3K30

    Mysql如何字符串添加索引(前缀索引)

    在日常开发中,我们经常字符串添加索引,那么字段添加索引有什么技巧吗,我们看看下面的例子,我们一个邮箱添加索引,应该如何添加呢 看看下面这条sql select * from user where...email ='jiepi@qq.com' 如果我们不添加索引,肯定是要进行全表扫描的,那么我们如何添加呢有两种方式 alter table user add index index1(email)...index2每个索引中仅仅存储了字段的前6个字符,而index1存储了整个字符串,我们分别在不同索引下执行下面的语句 select id,name,email from user where email...于是,我们发现选择合适的前缀长度,既可以节省空间,也可以不用增加更多的查询成本, 那么如何选择合适的前缀长度呢 建立索引之前,我们要关注字段的区分度,区分度越大,性能越高,意味着重复的值就越少。

    9.6K20

    MySQL深入学习第十一篇-怎么字符串字段索引?

    现在,几乎所有的系统都支持邮箱登录,如何在邮箱这样的字段上建立合理的索引,是我们今天要讨论的问题。...同时,MySQL 是支持前缀索引的,也就是说,你可以定义字符串的一部分作为索引。默认地,如果你创建索引的语句不指定前缀长度,那么索引就会包含整个字符串。...小结 在今天这篇文章中,我跟你聊了聊字符串字段创建索引的场景。我们来回顾一下,你可以使用的方式有: 1. 直接创建完整索引,这样可能比较占用空间; 2....因为维护的只是一个学校的,因此前面 6 位(其中,前三位是所在城市编号、第四到第六位是学校编号)其实是固定的,邮箱后缀都是 @gamil.com,因此可以只存入学年份顺序编号,它们的长度是 9 位。...其实这个就是一种 hash,只是它用了最简单的转换规则:字符串转数字的规则,而刚好我们设定的这个背景,可以保证这个转换后结果的唯一性。

    1.9K10

    外包根鸡腿!

    这些忍耐最终换来了外包公司变本厉的剥削,让外包的待遇和未来变的很差。如果甲方的公司再踩上一脚,就会让这些原本脆弱的神经变的更加敏感而悲伤。 不能这么做,也不要嘲笑外包。对外包善良,就是对自己善良。...低买,就是尽量降低外包员工的待遇,能少的少,能克扣的克扣。如果员工是一只羊,那么就把他身上的毛拔的一根不剩。 高卖,这就需要手段,要算好账,才不至于亏损。比较厉害的高卖,就是利益输送。...至于项目最终做的如何,只要不是太太过分,那就没什么人关心。 员工很苦 但 A 公司的研发负责人不这么想。他还想要个万能的产品。 这些外包出去的系统,A公司是要真正使用的。...抽点经费,在美好的星期四,同学们点上一只炸鸡,微微带点孜然香味,再撒上点胡椒粉,人间的温暖就此传递。 在这寒冬中,尤其珍贵。 作者简介:小姐姐味道 (xjjdog),一个不允许程序员走弯路的公众号。

    60910

    如何字符串字段家索引

    如何字符串字段索引 1. 常见的字符串索引有哪些 完整索引。 前缀索引。 倒叙索引。 哈希索引。 2. 完整索引 在整个字符串上建立索引。...2.1 完整索引的问题 完整索引使用整个字符串字段建立索引。当字段的长度过长时,会占用较多的存储空间。 3. 前缀索引 使用字符串的前n个字符创建索引。...3.1 如何确定前缀索引的n值 建议索引的关注点是区分度,即某列中不同的值的个数/数据总条数。区分度越高的时候,重复的值越少。...倒序索引 将字符串倒置,再创建前缀索引。 4.1 倒序索引的使用场景 字符串后几位的区分度更高,例如身份证的后六位。 4.2 倒序索引的问题 倒叙索引无法使用范围查询。 5....总结 最常见的字符串索引是完整索引,后续的改进都是为了减少字符串索引的存储空间,但同时引入了不同的问题。 在实际的应用中,需要根据不同的场景选择合适的策略。

    55720
    领券