mysql 前缀索引 语法_PHP 之Mysql优化

一、建立索引

1、前缀索引

建立前缀索引的语法:

alter table test add KEY (name(5));

name一定是字符类型(索引字段),5为长度

那好,如何确定取前面几个字符呢?显然,这个场景是一个观察的结果,也就是说,必须要有一定量的实际数据,我们才能分析出其规律,也就是说这个索引是在后期优化得来的,前期没必要建立。计算不重复的概率:

select COUNT(DISTINCT name) / COUNT(*) as rate from test;找出接近rate的一个n(试出最合理的n)

select COUNT(DISTINCT LEFT(name, 3)) / COUNT() as rate3 from test;

select COUNT(DISTINCT LEFT(name, 5)) / COUNT() as rate5 from test;

select COUNT(DISTINCT LEFT(name, 7)) / COUNT() as rate7 from test;

select COUNT(DISTINCT LEFT(name, 9)) / COUNT() as rate9 from test;

select COUNT(DISTINCT LEFT(name, 11)) / COUNT() as rate11 from test;

select COUNT(DISTINCT LEFT(name, 15)) / COUNT() as rate15 from test;

select COUNT(DISTINCT LEFT(name, 20)) / COUNT(*) as rate20 from test;

2、全文索引

该类型的索引特殊在:关键字的创建上。为了解决 like ‘%keyword%’这类查询的匹配问题。

查询 标题或者内容包含 database 关键字的记录。

形成的SQL如下:

Select * from articles where title like ‘%database%’ or body like ‘%database%’;

此时需要建立全文索引

直接使用上面的SQL:

需要使用特殊的全文索引匹配语法才可以生效:

Match() against();

注意:mysql提供的全文索引不能对中文起作用,可以采用Sphinx索引引擎。

Match() against() ,返回的关键字的匹配度(关键字与记录的关联程度)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/295274.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

别不承认!搞懂那些数理原理,才发现它们和枯燥根本不沾边!

▲ 点击查看数理化的学习对于很多孩子,包括家长都是一个大难题。比如,我们要教孩子认识动物,一般是要给孩子看动物的图片或实体,孩子自然就对这个动物有个认知。要教孩子数字,就会用一件玩具、两个苹果这种和现实有关联…

链表笔试题汇编(一)

题目:给定单向链表的头指针和一个结点指针,定义一个函数在O(1)时间删除该结点。分析:删除结点可以从链表的头结点开始顺序遍历,发现某个结点的next指向要删除的结点时,将该结点的next指向要删除的下一个结点。但是基于…

WPF实现数据拾取器

WPF开发者QQ群: 340500857 | 微信群 -> 进入公众号主页 加入组织由于在WPF中没有现成的数据拾取器控件,所以我们自己实现一个。PS:有更好的方式欢迎推荐。01—代码如下一、创建 RoundPicker.cs 继承 Control代码如下。RoundPicker.cs实现…

CAS的安装与配置(一)服务器端配置

一、搭建Java Web服务器环境 CATALINA_HOME D:\Java\apache-tomcat-6.0.14 安装完毕,启动Tomcat ,在浏览器上 测试 http://localhost:8080/ 出现上述界面,表明系统成功搭建。 二、使用Java Keytool工具为系统生成HTTPS证书,并…

某大型银行深化系统之十六:性能设计之一

传送门 ☞ 轮子的专栏 ☞ 转载请注明 ☞ http://blog.csdn.net/leverage_1229 1队列服务质量评估 通过引入排队系统,定义系统中各项业务流程的产生和业务服务模型,描述工作项产生规律和服务规律的概率来计算系统的性能。 在对排队进行分析时,…

Android之React native的介绍和入门指南

链接:http://zhuanlan.zhihu.com/FrontendMagazine/19996445数月前,Facebook 对外宣布了正在开发的 React Native 框架,这个框架允许你使用 JavaScript 开发原生的 iOS 应用——就在今天,Beta 版的仓库释出了! 基于 P…

mysql 堆叠查询_SQL 注入方法 - 盲注、报错注入、UNION查询注入与堆叠注入

盲注关键点是 根据页面返回内容分析 Payload 中的问题是否为真,然后通过多次测试遍历出想要的数据布尔盲注目标地址:http://newspaper.com/items.php?id2对应的SQL语句:SELECT title, description, body FROM items WHERE ID 2然后攻击者尝…

清华教授转述:读博6年未毕业被认定为自控力不够,或将影响个人贷款额度

全世界只有3.14 % 的人关注了爆炸吧知识图片来源:网络来源:募格课堂、微博人文清华、中国教育报、学位与写作据清华大学“人文清华”讲坛官方微博人文清华发布,清华大学公共管理学院院长江小涓教授在一次演讲中透露,互联网银行工作…

缕一缕c#可null类型

在古时候,引用类型是的默认值就是null,值类型是不可以赋值null的,所以那时候,“未将对象引用到实例”这个错误,是引用类型的。后来,值类型也可以赋值null了,只要在值类型变量定义的时候&#xf…

[原]NYOJ-开灯问题-77

大学生程序代写 //http://acm.nyist.net/JudgeOnline/problem.php?pid77/*题目77题目信息运行结果本题排行讨论区开灯问题时间限制:3000 ms | 内存限制:65535 KB难度:1描述有n盏灯,编号为1~n,第1个人把所有灯打开&a…

Android之Windows下搭建React Native Android开发环境(差不多搞了一天)

Android之Windows下搭建React Native Android开发环境 穷逼买不起mac,但是他们都说React Native Android只能在mac下面运行,然后到网上各种找资料看能不能在Windows下面搭建开发环境,找了几篇,但是讲得不够详细,没有图片,很虚,然后我用自己的小米手机尝试了…

这6部顶级数学纪录片,告诉你数学一点都不无趣!

全世界只有3.14 % 的人关注了爆炸吧知识丘成桐曾说,“中国数学发展很快,但距离欧洲和美国还有相当大的差距”,在美国排名前20的顶尖大学里,包括哈佛大学、普林斯顿大学、斯坦福大学、加州大学伯克利分校等,具有国际一流…

JAVA兔子繁衍_Java 编程经典案例之兔子繁殖迭代问题

题目有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第6个月的兔子总数为多少?分析首先我们要明白题目的意思指的是每个月的兔子总对数;假设将…

检查可执行文件所需要的共享库

1.3 ldd 和 ldconfigldd 是用来检查可执行文件所需要的共享库。例如:$ ldd /bin/lslibtermcap.so.2 > /lib/libtermcap.so.2 (0x4001c000)libc.so.6 > /lib/libc.so.6 (0x40020000)/lib/ld-linux.so.2 > /lib/ld-linux.so.2 (0x40000000)我们在 /bin/ls 程…

C# GTS四轴运动控制器实例(固高科技步进电机不带编码器) -V1

注:由于电机不带编码器,无法做home和当前位置信息读取!功能:三个轴的点位运动:前进后退,并分别显示每个轴的移动脉冲数(可以换算为距离)!开发环境:VS2017硬件设备:固高科…

node.js npm常用命令

npm是一个node包管理和分发工具,已经成为了非官方的发布node模块(包)的标准。有了npm,可以很快的找到特定服务要使用的包,进行下载、安装以及管理已经安装的包。 1、npm install moduleNames:安装Node模块 …

编程珠玑第三章

第三章的总的原则: 1.将重复性代码改到数组中,使用最简单的数据结构---数组来表示一段冗长的相类似的代码往往可以达到最佳效果 2.封装复杂的结构时,使用抽象的术语对她进行定义,并将那些操作表示成一个类。 3.尽可能地使用高级工…

java基础巩固笔记(6)-注解

2019独角兽企业重金招聘Python工程师标准>>> java基础巩固笔记(6)-注解 标签: java [TOC] 注解(Annotation),也叫元数据。一种代码级别的说明。它是JDK1.5及以后版本引入的一个特性,与类、接口、枚举是在同…

男人都能有多浪漫?

1 如何对付有拖延症的朋友!▼2 男人能有多浪漫?(via.MOM南菁)▼3 现实版:别说话吻我?(素材来源网络,侵删)▼4 注入了灵魂的神作!(素材来源网络…

在业务层实现记录请求日志

前言上次,我们介绍了如何《在业务层实现响应缓存》。今天,我们同样使用IPipelineBehavior,介绍如何在业务层实现记录请求日志,用于跟踪每个请求执行的耗时。Demo创建ASP.NET Core Web API项目,引用Nuget包:…