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

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

在日常开发中,我们经常给字符添加索引,那么给字段添加索引有什么技巧吗,我们看看下面的例子,我们给一个邮箱添加索引,应该如何添加呢 看看下面这条sql select * from user where...email ='jiepi@qq.com' 如果我们不添加索引,肯定是要进行全表扫描的,那么我们如何添加呢有两种方式 alter table user add index index1(email)...alter table user add index index2(email(6)) 上面两种方式都是在添加索引,不同点就是第二种添加的仅仅是邮箱的前缀索引,那么他的结构表现如下图 ?...index2每个索引中仅仅存储了字段的前6个字符,而index1存储了整个字符串,我们分别在不同索引下执行下面的语句 select id,name,email from user where email...其他方式 对于邮箱类型的字段,使用前缀索引是一个不错的选择,但是我们要是遇到前缀区分度不大的字段应该怎么办呢, 第一种,我们可以使用倒序存储,如果存储身份证,一般身份中前6位,一个省的值都是一样,而后几位区分度就还可以

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

    mysql 添加用户

    命令方式的.注意每行后边都跟个 ; 表示一个命令语句结束.....* to 用户名@登录主机 identified by “密码” 例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。...; 但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。...例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),...这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。

    4.5K40

    MySQL 特殊字符

    1.注释符 SQL 注释是用来在 SQL 语句中添加对代码的解释说明。SQL 支持两种类型的注释符号。 单行注释:使用两个连续的减号(–)表示。减号后面的内容将被视为注释,直到该行结束。...如果字符串中包含单引号该如何表示呢? 在 SQL 中,如果要表示一个带有单引号的字符串有多种方式。 可以使用反斜杠(\)进行转移,也可以使用单引号进行转义,即使用两个单引号来表示一个单引号。...SELECT 'It\'s a beautiful day'; SELECT 'It''s a beautiful day'; 因为 MySQL 支持使用双引号表示字符串,所以还可以使用双引号表示一个包含单引号的字符串...如果你希望使用一个MySQL 中的保留字同名的标识符,可以使用反引号将其括起来,以避免语法错误。...当我们想要判断字符串中是否包含这两个字符时,例如“50%”,就需要使用一个转义字符将模式中的通配符解释为普通字符

    78960

    一个慢查询到MySQL字符集编码

    由上面的概念可以见得,字符集就是一组字符的抽象集合,也可以称为字符集合,例如所有的汉字可以算成一个字符集,所有的英文字母也可以算成一个字符集。...,第二列是字符集的描述,第三列是字符集默认的排序规则,第四列表示一个字符集的一个字符最大的字节数。...翻译过来就是collation就是一套规则,用来比较字符集中的字符。那么怎么理解这个比较字符集中的字符呢?文档给出了一个例子,例如有一个简单的字符集包括了如下的几个字符:a b A B。...(Trailing Space Handling in Comparisons) 对于具有_bin 后缀的collation的字符集,字符串最后的一个空格,在比较字符串是否相等的时候不会被计入: mysql...以前经常遇到这样一个问题: Latin1字符集是否支持中文? 为了说明这个问题,本文来做如下的测试: 设置终端字符集为utf8。 mysql的所有字符集配置都改成latin1。

    28110

    mysql字符函数

    然后拼接 4. substr、substring (1) 截取从指定索引处后面所有字符 (2) 截取从指定索引处指定字符长度的字符 案例1:姓名中首字符大写,其他字符小写然后用_拼接,显示出来 5....常见函数: 一、单行函数 字符函数: length:获取字节个数(utf-8一个汉字代表3个字节,gbk为2个字节) concat substr instr trim upper lower...这里客户端使用的字符集是utf-8,一个汉字等于三个字节,所以为12 注意: 查看客户端使用的字符集,这里使用的是 utf-8,一个汉字占三个字节,一个英文占一个字节。...如果客户端使用的字符集是gbk,那就是一个汉字占两个字节,一个英文占一个字节。 SHOW VARIABLES LIKE '%char%' ?...(2) 截取从指定索引处指定字符长度的字符 这里的第一个参数表示从第一个索引开始,第二个参数表示字符的长度 SELECT SUBSTR('李莫愁爱上了陆展元',1,3) out_put; ?

    86510

    MySQL设置字符编码

    正文 1.首先连接到MySQLmysql -uroot -proot 2.输入\s,即可查看数据库的字符编码 3.查看数据库的详细编码   输入:show variables like '%char...%'; 4.新建一个数据库查看数据库编码   create database test1;   show create database test1; 5.设置当前窗口的数据库字符编码,即使基于会话...如图:   因为是基于会话级别的改变编码的方式,当重新新建一个窗口连接的时候,会话已经改变,所以变为了原来的字符编码。...6.设置全局的数据库字符编码,即使基于整个MySQL服务的,当重启MySQL服务的时候,编码依然会变为原来的字符编码   set global character_set_database=gbk;   ...重点是在另一个窗口中的编码现实的是什么,下面我们复制一个窗口,新建数据库,来查看数据库和表的编码   create database test3;   show variables like '%char

    5.7K20

    MySQL字符

    MySQL字符字符集介绍 gbk/gb2312 gbk/gb2312 采用双字节字符集,不论中、英文字符均使用双字符来表示,为了区分中文,将其最高位都设定成1 gb2312是gbk的子集,gbk...2个字节来存储,而常用的汉字就要用3个字节;也就是一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。...存储空间:char(N)类型的存储空间和字符集有关系,结合刚才字符集的知识点,一个中文在utf8字符集中占用3个bytes、gbk占用2个bytes、数字和字符统一用一个字符表示。...存储空间:varchar(N)类型的存储空间和字符集有关系,结合刚才字符集的知识点,一个中文在utf8字符集中占用3个bytes、gbk统一占用2个bytes、数字和字符一个字符表示。...(长度小于255字节,使用一个字节来表示长度;大于255字节使用两个字节来表示长度) 修改数据库实例字符集 临时生效 mysql> set character_set = 'gbk'; mysql> set

    3.6K10
    领券