mysql模糊查询结果取反问题

 更新时间:2023年09月01日 08:37:43   作者:qq_35327536  
这篇文章主要介绍了mysql模糊查询结果取反问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql模糊查询结果取反

问题描述

1、表结构:

 

2、只要包含3这种类型的都不能查询。 

解决方式

1、模糊查询出所有包含3这种类型的数据,在使用not in这种方式:

SELECT * FROM system_account WHERE id NOT IN (SELECT id FROM system_account WHERE identity_type LIKE "%3%");

这种方式如果类型中有13、23这种带3的类型就需要修改模糊条件。

2、使用正则匹配方式:

SELECT * FROM `system_account` WHERE identity_type REGEXP "^([1,2,4,5,6,7,8,9]{1}\,?)*[1,2,4,5,6,7,8,9]{1}$";

这种方式只要在这种中排除3这种类型就可以了,但是没添加一种类型就需要修改一次sql语句。

同事问的这个问题,第一反应是模糊查询取反,所以感觉很有意思就记录一下。

最终这种方案也没有用上,同事把需求弄反了。

模糊查询可以使用 not like 这种查询方式 平时从来没有用过也没看见过 所以没想到这种方法

SELECT * FROM admin_produce_order WHERE product_code LIKE 'CP211%' AND po_come_factory NOT LIKE "%罗西%"

mysql模糊匹配后匹配优化

线上存在业务代码,需要模糊匹配且进行后匹配

select * from test where id like "%1231"

优化过程

mysql的后模糊匹配是不走索引的,所以数量级增大后,sql执行速度会越来越慢,但是业务一定要保留该功能,且频繁调用;

处理方案:

1. 使用表中已存在的其他列索引

如果查询的表存在其他列索引,可以直接使用模糊匹配查询完整的主键信息,再进行业务查询

select id from test where id like "%1231"
select * from test where id = #{id}

该方案简单迅速,查询索引级别一般可以达到index

2. 使用缓存记录模糊匹配列所有数据

先进行缓存记录所有模糊列数据,再经过缓存进行数据匹配,最后进行业务查询。

该方案需要保证缓存可靠,并且及时更新

3. 数据库增加相反列,并设置对应索引

例如,原模糊列为id,值为123,相反列起名id_reverse,值则为321

当进行模糊匹配时,先对传入参数进行却反,123取反为321,最后用相反列进行匹配

select * from test where id_reverse like "321%"

如果需要保证该条件同时满足前匹配和后匹配

select * from test where id like "123%" or id_reverse like "321%"

该方案需要保证相反列和模糊列数据保持相反,并同步更新,索引级别可达range

type索引类型:

ststem > const > eq_ref > ref > range > index > all

优化级别从左往右递减,没有索引的一般为’all’,需要对type进行优化前提是有索引。

其中’system’和’const’只是理想型,实际只能达到’ref’和’range’。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 绿色版mysql注册卸载服务方法

    绿色版mysql注册卸载服务方法

    如果直接用绿色版的mysql,则下载后解压,只需对目录下的my.ini文件的basedir(mysql的基本目录)和datadir(mysql数据目录)指定就可以,如下所示。
    2013-06-06
  • MySQL约束之默认约束default与零填充约束zerofill

    MySQL约束之默认约束default与零填充约束zerofill

    这篇文章主要介绍了MySQL约束之默认约束default与零填充约束zerofill,MySQL 默认值约束用来指定某列的默认值。更多相关资料需要的朋友可以参考一下
    2022-07-07
  • MySQL约束constraint用法详解

    MySQL约束constraint用法详解

    大家都知道MySQL中经常会需要创建父子表之间的约束,下面这篇文章主要给大家介绍了关于MySQL约束constraint用法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • mac系统下mysql 8.0.11 安装指南

    mac系统下mysql 8.0.11 安装指南

    这篇文章主要为大家详细介绍了mac系统下mysql 8.0.11 安装指南,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Docker安装mysql配置大小写不敏感挂载数据卷存储操作步骤

    Docker安装mysql配置大小写不敏感挂载数据卷存储操作步骤

    这篇文章主要介绍了Docker安装mysql配置大小写不敏感挂载数据卷存储操作步骤详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • Mysql深入了解联表查询的特点

    Mysql深入了解联表查询的特点

    这篇文章主要给大家介绍了关于MySQL联表查询的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2022-07-07
  • MySQL索引优化Explain详解

    MySQL索引优化Explain详解

    这篇文章主要介绍了MySQL索引优化Explain详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • MySQL千万级大数据SQL查询优化知识点总结

    MySQL千万级大数据SQL查询优化知识点总结

    在本篇文章里小编给大家整理的是一篇关于MySQL千万级大数据SQL查询优化知识点总结内容,有需要的朋友们可以学习参考下。
    2019-12-12
  • MYSQL使用inner join 进行 查询/删除/修改示例

    MYSQL使用inner join 进行 查询/删除/修改示例

    本文为大家介绍下使用inner join 进行查询/删除/修改,具体实现如下,学习mysql的朋也可以学习下,希望对大家有所帮助
    2013-07-07
  • MySQL如何查询Binlog 生成时间

    MySQL如何查询Binlog 生成时间

    这篇文章主要介绍了MySQL如何查询Binlog 生成时间,通过读取 Binlog FORMAT_DESCRIPTION_EVENT header 时间戳来实现读取 Binlog 生产时间,本文给大家详细讲解,需要的朋友可以参考下
    2023-03-03

最新评论