如何优化like左模糊匹配

            通常我们大家都知道最左前缀匹配原则,如果like '%XY'这种情况就没办法使用索引,但是在业务场景中,这种情况又非常常见,那么针对这种情况该怎么优化呢?

            1.可以将要全模糊匹配的列reverse存储,这样就可以通过like 'XY%'  or reverse的列 like  ‘YX%’ 的形式来实现,走索引

             

            2.建立联合索引,使用索引覆盖的技术来让左模糊匹配也能走索引。索引覆盖指的是select的字段和where查询需要的字段在索引中都存在,不需要回表进行操作。

               通常在Extra列会有using where 表示需要回表,如果利用了覆盖索引,则会是 using index.

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基本功能: 1、 建立数据库表 2、 能够对数据库中的单表进行数据导入 3、 能够对数据库中的单表进行插入 4、 能够对数据库中的单表进行查询 5、 能够对数据库中的单表进行更新 6、 能够对数据库中的单表进行删除 高级功能: 当数据量比较大的时候,请大家建立索引,并通过索引加快查询速度(选作) 要求: 1、 不能使用Cstring.h,string等类,只能使用char* 来处理字符串 2、 能够动态的申请和分配内存 上交的内容: 1、.cpp、.h、.exe文件 2、文件命名规则:学号_[数字].cpp 学号_[数字].h 学号.exe 程序具体要求: 1、 在命令行下运行 学号.exe 2、 按输入参数 a) –c 文件路径名 表示根据指定位置的文件内语句建立一个数据库表 文件格式如下:   CREATE TABLE table_name (column_name datatype(datalength) [NULL/NOT NULL];   …   ?)      参数说明   table_name:是新表的名称。表名最多可包含 128 个字符   column_name:是表中的列名。列名必须符合标识符规则,并且在表内唯一。 datatype:是表中的列的数据类型。要求支持以下两类:数字(float)和字符串(char) datalength:是表中的列的数据长度。如果datatype是数字,长度一律为4,如果是字符串,则表示允许的字符串的最大长度。 [NULL/NOT NULL]:是表中列的取值是否能为空的标志。[]表明本项可不出现。如果不出现,默认为NULL,也就是可以为空。   参数之间以单个空格分开。多列之间以分号分隔。 b) –i 数据库表名 数据文件路径名 表示从指定文本文件中导入数据到数据库的表中 数据文件格式如下:   每条记录占一行,一行中的数据每列之间以逗号分隔。 注意:实际提交后测试的数据文件中的数据量可能会比较大,几万条,上百兆。   举例:(上面建立的student表的数据)   1,aaa,97   2,bbb,87   3,ccc,56    c) –s 文件路径名 表示从指定文本文件中读取语句执行查询操作 文件格式如下:   select [TOP n] * | {column_name} from table_name [where colume_name like | = column_value and | or … [order by column_name [ASC | DESC] ] ]   参数说明:   TOP n:表示查询结果显示最多多少个,n为显示的记录条数;[]表明本项可不出现。   |:表明|的边和右边为“或”的关系,只出现任一项即可;   *:代表所有的列名;   {column_name}:是希望筛选的列名的表列,多个列名以逗号分隔,{}必须要有。 table_name:是数据库中待进行筛选操作的表名。 column_value:是表中该列的数据值。 like|=:字符串型的column_value用=关键字,表明精确匹配;用like关键字,表明模糊匹配,即column_value应当是列中值的子串。   数值型的column_value用=关键字,精确查询;不支持用like关键字。 and|or:表明多个筛选条件的逻辑关系。 order by: 表示按照后跟的column_name列进行排序,ASC表示升序,DESC表示降序,默认是升序排列。 查询后,将查询结果在屏幕上显示出来,应计算本次查询操作所花费的执行时间,并生成 学号_select_序号.txt的文本文件,在文件的开头写明: Execute Time: …ms   Execute Result:   查询结果    d) –u 文件路径名 表示从指定文本文件中读取语句执行更新操作 文件格式如下:   update table_name set colume_name = column_value [where column_name = column_value and | or …]   参数说明   column_name:是表中的列名。 table_name:是数据库中的表名 column_value:是表中的列的数据值。 更新后,将更新结果在屏幕上显示出来, 应计算本次更新操作所花费的执行时间,并生成 学号_update_序号.txt的文本文件,在文件的开头写明: Execute Time: …ms   Execute Result:   更新后的结果    e) –d 文件路径名 表示从指定文本文件中读取语句执行删除操作 文件格式如下: delete from table_name [where column_name = column_value]   参数说明   column_name:是表中的列名。 Table_name:是数据库中的表名 Column_value:是表中的列的数据值。 删除后,将删除结果在屏幕上显示出来, 应计算本次删除操作所花费的执行时间,并生成 学号_delete_序号.txt的文本文件,在文件的开头写明: Execute Time: …ms   Execute Result:   删除后的结果 f) –h 帮助信息,提示各个参数的格式和含义 g) –q 退出程序 h) –index 0/1 0表示关闭索引功能,1表示打开索引功能,即在接下来的查询、更新、删除操作中使用索引。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值