0929mysql前缀索引如何找到合适的位数
前缀索引,是指对于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前缀索引如何找到合适的位数的更多相关文章
- MySQL前缀索引和索引选择性
有时候需要索引很长的字符列,这会让索引变得大且慢.通常可以索引开始的部分字符,这样可以大大节约索引空间,从而提高索引效率.但这样也会降低索引的选择性.索引的选择性是指不重复的索引值(也称为基数,car ...
- mysql索引之一:索引基础(B-Tree索引、哈希索引、聚簇索引、全文(Full-text)索引区别)(唯一索引、最左前缀索引、前缀索引、多列索引)
没有索引时mysql是如何查询到数据的 索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点.考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页面大小为4K,并存储10 ...
- 一文搞懂MySQL前缀索引
引入 通常在开发中我们需要定义字符串类型的字段,例如用户名或者用户邮箱等. 假设我们在维护一个用户登录系统,用户表的定义: create table User( ID bigint unsigned ...
- MySQL的前缀索引及Oracle的类似实现
MySQL有一个很有意思的索引类型,叫做前缀索引,它可以给某个文本字段的前面部分单独做索引,从而降低索引的大小. 其实,Oracle也有类似的实现,对于文本,它可以通过substr的函数索引,实现同样 ...
- mysql索引之四:复合索引之最左前缀原理,索引选择性,索引优化策略之前缀索引
高效使用索引的首要条件是知道什么样的查询会使用到索引,这个问题和B+Tree中的“最左前缀原理”有关,下面通过例子说明最左前缀原理. 一.最左前缀索引 这里先说一下联合索引的概念.MySQL中的索引可 ...
- Mysql使用Java UUID作为唯一值时使用前缀索引测试
Mysql可以使用字符串前缀 作为索引 以节约空间. 下面我们以 Java的UUID 生成的 32位(移除UUID中的 中划线)字符串 来做一下 测试. 表结构: CREATE TABLE `test ...
- MySQL的索引类型和左前缀索引
1.索引类型: 1.1B-tree索引: 注:名叫btree索引,大的方面看,都用的是平衡树,但具体的实现上,各引擎稍有不同,比如,严格的说,NDB引擎,使用的是T-tree,但是在MyISAM,In ...
- MySQL索引之前缀索引和索引选择性
有时需要索引很长的字符列,它会使索引变大而且变慢.一个策略就是模拟哈希索引.但是有时这也不够好,那? 通常可以索引开始的几个字符,而不是全部值,以节约空间并得到好的性能.这使索引需要的空间变小,但是也 ...
- BLOB或TEXT字段使用散列值和前缀索引优化提高查询速度
1.创建表,存储引擎为myisam,对大文本字段blob使用MD5函数建立一个散列值 create table t2(id varchar(60), content blob, hash_value ...
随机推荐
- Linux下ejabberd开机自启(CentOS)
废话少说,Linux下开机自启动Ejabberd步骤如下: 1.从ejabberd安装目录的bin目录拷贝ejabberd.init到/etc/init.d/ejabberd下 [root@imser ...
- [转][MVC] 剖析 NopCommerce 的 Theme 机制
本文转自:http://www.cnblogs.com/coolite/archive/2012/12/28/NopTheme.html?utm_source=tuicool&utm_medi ...
- java设计模式:单例模式
单例模式:运行期间有且仅有一个实例 1.一个类只有一个实例 2.必须自行创建这个实例 3.必须自行向整个系统提供这个实例 懒汉模式: 在类加载时不创建实例,运行调用时创建.类加载快,在运行时获取对象慢 ...
- C# 事件编程在游戏开发的应用
2D碰撞检测:http://wenku.baidu.com/view/45544cfcfab069dc50220145.html 1.Action System.Action 等于快捷创建一个委托 2 ...
- android整体架构概述--①
android的logo 是由设计师去厕所时来的灵感. 其中android的命名都是以甜点的名字来定的. android的系统一共有四层. 1.Linux内核和驱动层 2.函数库 由C或C++编写 ...
- JSP前三章错题整理
A: B: C: D: web-inf目录中的文件不能被客户端直接访问. 正确答案是 C 您回答的是 D 回答错误 试题分析纠错设为收藏 (选择一项) 14 A: B: C: Tomcat作为Web ...
- 花生壳动态IP域名解析之python自动提交公网IP
#!/usr/bin/env python import re import os import time import random ip_current = '' while True: myip ...
- MakeCode 递归生成资源文件
static void yieldDir(DirectoryInfo dir, int depth, StringBuilder sb1, StringBuilder sb2) { var first ...
- [资料]mysql实现地理位置搜索
mysql实现地理位置搜索 使用mysql来实现lbs(地理位置服务)功能 Mysql 地区经纬度 查询
- ssh生成key不交互
ssh-keygen -t rsa -f ~/.ssh/id_rsa -P "" 首次执行不交互 第二次再次执行会让输入y