前缀索引,是指对于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. Terminal中输入命令直接打开QtCreator,以及创建其桌面快捷方式

    工业项目设计学习第一步,熟悉开发工具 Qt学习论坛,东西多,但也杂 emouse的博客,以前学习STM32开发环境搭建时也是参考这位博主的 更多详细的步骤在上面都能找到,今天先不写,等明天把硬件设备全 ...

  2. NOIP水题合集[3/未完待续]

    NOIP2008pj传球游戏 题目描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次,老师带着同学们一起做传球游戏. 游戏规则是这样的:n个同学站成一个圆圈,其中的一个同学手里拿着一个球, ...

  3. 第16章 调色板管理器_16.4 一个DIB位图库的实现(2)

    //接上一篇 //DibPal.h /*----------------------------------------------------------------- DIBPAL.H heade ...

  4. Serializable

    import java.io.*;    public class  Box implements Serializable   {       private int width;       pr ...

  5. Redis的安装和使用

    Redis 安装redis: 将将要安装redis文件夹放到一个盘中 通过命令行切换到放文件的地方 安装成功后,将文件夹中的扩展放入wamp/php/ext中,然后配置php.ini,重启服务器. 使 ...

  6. struts2配置详解

    01.Struts 2基本结构 使用Struts2框架实现用登录的功能,使用struts2标签和ognl表达式简化了试图的开发,并且利用struts2提供的特性对输入的数据进行验证,以及访问Servl ...

  7. 使用exp进行SQL报错注入

    0x01 前言概述 好消息好消息-作者又在MySQL中发现了一个Double型数据溢出.如果你想了解利用溢出来注出数据,你可以读一下作者之前发的博文:BIGINT Overflow Error bas ...

  8. Oracle过程及函数的参数模式,In、out、in out模式

    Oracle过程及函数的参数模式 In.out.in out模式 在Oracle中过程与函数都可以有参数,参数的类型可以指定为in.out.in out三种模式. 三种参数的具体说明,如下图所示: ( ...

  9. flask表单提交的两种方式

    一.通用方式 通用方式就是使用ajax或者$.post来提交. 前端html <form method="post" action="/mockservice&qu ...

  10. 漫谈python中的搜索/排序

    在数据结构那一块,搜索有顺序查找/二分查找/hash查找,而排序有冒泡排序/选择排序/插入排序/归并排序/快速排序.如果遇到数据量和数组排列方式不同,基于时间复杂度的考虑,可能需要用到混合算法.如果用 ...