前缀索引,是指对于VARCHAR/TEXT/BLOB类型的字段建立索引时一般都会选择前N个字符作为索引。索引很长的字符列,会让索引变得大且慢。索引开始的部分字符,这样可以大大节约索引空间,从而提高索引效率,但这样也会降低索引的选择性。索引的选择性是指不重复的索引值(也称为基数,cardinality)和数据表的记录总数的比值。
计算公式:
SELECT COUNT(DISTINCT(a))/COUNT(*) FROM table1;

SELECT COUNT(DISTINCT(LEFT((UUID),2)))/COUNT(1) AS ind2,
COUNT(DISTINCT(LEFT((UUID),3)))/COUNT(1) AS ind3,
COUNT(DISTINCT(LEFT((UUID),4)))/COUNT(1) AS ind4,
COUNT(DISTINCT(LEFT((UUID),5)))/COUNT(1) AS ind5,
COUNT(DISTINCT(LEFT((UUID),6)))/COUNT(1) AS ind6,
COUNT(DISTINCT(LEFT((UUID),7)))/COUNT(1) AS ind7
FROM table_a;
选择=5的时候 即索引长度为5[效果更加接近1]

如何给字段的后几个字符加索引而不是给整个字段加
表里边有一个字段image_url,想给他加索引但是这个字段有很多内容是重复的如下:
image_url
http://img1.douban.com/lpic/s10419031.jpg
http://img1.douban.com/lpic/s10419532.jpg
http://img2.douban.com/lpic/s10412033.jpg
http://img2.douban.com/lpic/s10412034.jpg
给整个字段加索引会不会有问题啊?
能不能就只给这个字段的后13个字符加索引啊,因为这13个字符才是我查找用的数据?
还有加上以后用这个索引的时候,要注意哪些东西?

据我所知,MYSQL没有后缀索引(如果说错请指正);
如果真相要对这个字段添加索引又不想加整个字段,给你出歪招,程序可能稍微多一步。
创建字段image_url 按你的字符数添加前缀索引。存取该字段时反转字符传存储。结果如下:
gpj.13091401s/cipl/moc.nabuod.1gmi//:ptth
查询的时候反转一下就可以了。

SELECT COUNT(DISTINCT(LEFT(REVERSE(msg_id),2)))/COUNT(1) AS ind2,
COUNT(DISTINCT(LEFT(REVERSE(msg_id),3)))/COUNT(1) AS ind3,
COUNT(DISTINCT(LEFT(REVERSE(msg_id),4)))/COUNT(1) AS ind4,
COUNT(DISTINCT(LEFT(REVERSE(msg_id),5)))/COUNT(1) AS ind5,
COUNT(DISTINCT(LEFT(REVERSE(msg_id),6)))/COUNT(1) AS ind6,
COUNT(DISTINCT(LEFT(REVERSE(msg_id),7)))/COUNT(1) AS ind7
FROM table_a;

选择=6的时候 即索引长度为6
使用了反转函数 因为前面几位是相同的,所以在建表的时候将数据反写存进去,取得时候使用REVERSE反取一下即可

0929mysql前缀索引如何找到合适的位数的更多相关文章

  1. MySQL前缀索引和索引选择性

    有时候需要索引很长的字符列,这会让索引变得大且慢.通常可以索引开始的部分字符,这样可以大大节约索引空间,从而提高索引效率.但这样也会降低索引的选择性.索引的选择性是指不重复的索引值(也称为基数,car ...

  2. mysql索引之一:索引基础(B-Tree索引、哈希索引、聚簇索引、全文(Full-text)索引区别)(唯一索引、最左前缀索引、前缀索引、多列索引)

    没有索引时mysql是如何查询到数据的 索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点.考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页面大小为4K,并存储10 ...

  3. 一文搞懂MySQL前缀索引

    引入 通常在开发中我们需要定义字符串类型的字段,例如用户名或者用户邮箱等. 假设我们在维护一个用户登录系统,用户表的定义: create table User( ID bigint unsigned ...

  4. MySQL的前缀索引及Oracle的类似实现

    MySQL有一个很有意思的索引类型,叫做前缀索引,它可以给某个文本字段的前面部分单独做索引,从而降低索引的大小. 其实,Oracle也有类似的实现,对于文本,它可以通过substr的函数索引,实现同样 ...

  5. mysql索引之四:复合索引之最左前缀原理,索引选择性,索引优化策略之前缀索引

    高效使用索引的首要条件是知道什么样的查询会使用到索引,这个问题和B+Tree中的“最左前缀原理”有关,下面通过例子说明最左前缀原理. 一.最左前缀索引 这里先说一下联合索引的概念.MySQL中的索引可 ...

  6. Mysql使用Java UUID作为唯一值时使用前缀索引测试

    Mysql可以使用字符串前缀 作为索引 以节约空间. 下面我们以 Java的UUID 生成的 32位(移除UUID中的 中划线)字符串 来做一下 测试. 表结构: CREATE TABLE `test ...

  7. MySQL的索引类型和左前缀索引

    1.索引类型: 1.1B-tree索引: 注:名叫btree索引,大的方面看,都用的是平衡树,但具体的实现上,各引擎稍有不同,比如,严格的说,NDB引擎,使用的是T-tree,但是在MyISAM,In ...

  8. MySQL索引之前缀索引和索引选择性

    有时需要索引很长的字符列,它会使索引变大而且变慢.一个策略就是模拟哈希索引.但是有时这也不够好,那? 通常可以索引开始的几个字符,而不是全部值,以节约空间并得到好的性能.这使索引需要的空间变小,但是也 ...

  9. BLOB或TEXT字段使用散列值和前缀索引优化提高查询速度

    1.创建表,存储引擎为myisam,对大文本字段blob使用MD5函数建立一个散列值 create table t2(id varchar(60), content blob, hash_value ...

随机推荐

  1. Linux下Redis开机自启(Centos)

    废话少说,直接来步骤: 1.设置redis.conf中daemonize为yes,确保守护进程开启. 2.编写开机自启动脚本 vi /etc/init.d/redis 脚本内容如下: # chkcon ...

  2. java报表工具FineReport的SQL编辑框的语法简介

    感谢大家捧场,这里继续分享关于SQL编辑框的一些语法心得总结,因为数据集定义的面板,也是FineReport报表中最常用的模块之一. 1.我理解的执行过程. 这里其实是生成一个字符串,FineRepo ...

  3. [转]Using Entity Framework (EF) Code-First Migrations in nopCommerce for Fast Customizations

    本文转自:https://www.pronopcommerce.com/using-entity-framework-ef-code-first-migrations-in-nopcommerce-f ...

  4. SpringMVC从入门到精通之第一章

    第一节 简介:SpringMVC是Spring框架的一个模块,Spring和SpringMVC无需通过中间整合层进行整合.SpringMVC是基于MVC的WEB框架.MVC设计模式在B/S下的应用: ...

  5. Activity的onCreate()的PersistableBundle 参数坑。

    Bundle 与 PersistableBundle 区别 仅仅是Activity oncreate()的一个参数与两个参数的区别: @Override public void onCreate(Bu ...

  6. NOIP2012pj文化之旅[floyd]

    描述 有一位使者要游历各国,他每到一个国家,都能学到一种文化,但他不愿意学习任何一种文化超过一次,即如果他学习了某种文化,则他就不能到达其他有这种文化的国家.不同的国家可能有相同的文化.不同文化的国家 ...

  7. PAT 1012. 数字分类 (20)

    给定一系列正整数,请按要求对数字进行分类,并输出以下5个数字: A1 = 能被5整除的数字中所有偶数的和: A2 = 将被5除后余1的数字按给出顺序进行交错求和,即计算n1-n2+n3-n4...: ...

  8. PAT 1005. 继续(3n+1)猜想 (25) JAVA

    当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候,我们需要计算3.5.8.4.2.1,则当我们对n=5.8.4.2进行验证的时候,就可以直接 ...

  9. ios开发--多台电脑共用一个开发证书的方法

    Xcode5 以前的操作步骤是: idp证书如何给另一台机子使用 先在原电脑上用Xcode->Windows->Organizer, 再点击Developer profile, 在其最下面 ...

  10. Map集合 总结

    (本人第一次写博客,部分内容有参照李刚老师的疯狂java系列图书,如有遗漏错误,请多指教,谢谢.) Java的集合类可分为Set.List.Map.Queue,其中Set.List.Queue都有共同 ...