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

mysql如何写不包含

在MySQL中,如果你想查询不包含某个特定值的数据,可以使用NOT LIKE操作符。以下是一个基本的示例:

代码语言:txt
复制
SELECT * FROM table_name WHERE column_name NOT LIKE '%value%';

在这个查询中:

  • table_name 是你要查询的表的名称。
  • column_name 是你要检查的列的名称。
  • %value% 是你要排除的值。%是一个通配符,表示任意数量的字符。

这个查询将返回table_name表中column_name列的值不包含value的所有行。

应用场景

假设你有一个博客系统,你想找出所有标题中不包含"教程"二字的文章。你可以这样写:

代码语言:txt
复制
SELECT * FROM articles WHERE title NOT LIKE '%教程%';

类型

  • 字符串不包含查询:如上例所示,使用NOT LIKE进行字符串不包含的查询。
  • 数字范围排除:如果你想排除某个数字范围,可以使用NOT BETWEEN操作符。
  • 数字范围排除:如果你想排除某个数字范围,可以使用NOT BETWEEN操作符。
  • 日期排除:对于日期字段,也可以使用NOT BETWEEN来排除特定日期范围的数据。
  • 日期排除:对于日期字段,也可以使用NOT BETWEEN来排除特定日期范围的数据。

遇到的问题及解决方法

问题:查询速度慢。 原因:可能是因为没有为搜索列创建索引,或者数据量过大。 解决方法

  1. 为搜索列创建索引:
  2. 为搜索列创建索引:
  3. 优化查询条件,尽量减少返回的数据量。
  4. 如果数据量非常大,考虑分区表或者使用更高级的搜索技术,如全文搜索。

问题LIKE操作符使用不当导致全表扫描。 原因:如果LIKE操作符的模式以通配符开始(例如'%value'),MySQL将无法使用索引,导致全表扫描。 解决方法:确保LIKE模式以具体字符开始,如'value%'

通过这些方法,你可以有效地在MySQL中进行不包含特定值的查询,并解决可能遇到的一些常见问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • MySQL 关键字专题(包含COLLATE)

    对于 mysql 中那些字符类型的列,如 VARCHAR,CHAR,TEXT 类型的列,都需要有一个 COLLATE 类型来告知 mysql 如何对该列进行排序和比较。...这里顺便讲个题外话,mysql中有utf8和utf8mb4两种编码,在mysql中请大家忘记utf8**,永远使用 utf8mb4。...这是 mysql 的一个遗留问题,mysql中的utf8最多只能支持 3 bytes 长度的字符编码,对于一些需要占据 4 bytes 的文字,mysql的utf8就不支持了,要使用 utf8mb4 才行...在 mysql 中使用show collation指令可以查看到 mysql 所支持的所有COLLATE。以utf8mb4 为例,该编码所支持的所有 COLLATE 如下图所示。...以上就是关于 mysql 的 COLLATE 相关知识。不过,在系统设计中,我们还是要尽量避免让系统严重依赖中文字段的排序结果,在 mysql 的查询中也应该尽量避免使用中文做查询条件。

    1.3K20

    MySQL replace命令,建议使用。

    MySQL replace操作导致主从自增主键不一致 今天在线上遇到一个问题,是由于replace语法导致的主从自增主键不一致问题,这里我模拟了一下,问题能够稳定复现。...希望大家后续过程中,不要踩坑 01 问题还原 环境介绍: MySQL版本5.7.18 关键参数介绍: binlog_format:row binlog_row_image:full 主库操作 主库上创建一个表...*/; 在这个实验的过程中,我分别测试了MySQL8.0版本和MySQL5.7版本,发现MySQL8.0的版本,虽然binlog内容一致,但是更新了AUTO_INCREMENT的值。...这个现象,可以理解为MySQL 5.7 版本的一个bug。 03 潜在影响 可能你会想,如果主库此时利用replace操作插入一个冲突的新的数据记录,这个从库的自增值不就又同步了么。...4 | aaa | 4 | +----+------+------+ 3 rows in set (0.13 sec) 但是新主库的auto_increment值是4,意味着新主库上下一个指定自增

    2.3K20

    死锁处理,拿钱走人【mysql

    mysql有哪些锁 大并发情况下会引起几个数据问题 1.1脏读 一个事务读取另一个事务未提交的问题 解决脏读 修改时加排他锁(写锁),直到事务提交后才释放,读取时加共享锁(读锁),其他事务只能读取,不能再有更新操作...官方给出的幻读解释是:只要在一个事务中,第二次select多出了row就算幻读 1.4行锁表锁与页锁 行级锁是mysql中锁定粒度最细的一种锁。...行级锁分为共享锁和排他 表级锁是mysql中锁定粒度最大的一种锁,表示对当前操作的整张表加锁,它实现简单,资源消耗较少,被大部分mysql引擎支持。...最常使用的MyISAM与InnoDB都支持表级锁定 页级锁是 MySQL 中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁速度快,但冲突多,行级冲突少,但速度慢。...生产环境推荐使用过大的 innodb_lock_wait_timeout参数值 该参数支持在会话级别修改,方便应用在会话级别单独设置某些特殊操作的行锁等待超时时间,如下: set innodb_lock_wait_timeout

    1K20

    MySQL为什么推荐使用in

    当使用IN语句时,MySQL可能会遇到以下问题: 索引问题:MySQL使用索引来加速查询,但在使用IN语句时,MySQL可能无法有效地使用索引。...当MySQL无法使用索引时,它将执行全表扫描,逐行比较每个值,这会导致查询性能下降。 内存消耗:当使用IN语句时,MySQL需要将值列表中的所有值加载到内存中进行比较。...查询优化器的限制:MySQL的查询优化器在处理IN语句时可能会遇到一些限制。例如,优化器可能无法准确估计IN语句的选择性,从而导致选择不合适的查询计划。...在优化查询性能时,我们可以使用MySQL的查询分析工具来帮助我们理解查询的执行计划和性能瓶颈,从而做出更好的决策。

    34930

    mysql执行命令_linux mysql启动命令

    groupadd mysql useradd -r -g mysql mysql cd /usr/local tar zxvf /path/to/mysql-VERSION-OS.tar.gz ln -...s full-path-to-mysql-VERSION-OS mysql cd mysql chown -R mysql . chgrp -R mysql . scripts/mysql_install_db...,否则你输入mysql命令时报错:“-bash: mysql: command not found” 二 设置mysql环境变量 如果不能使用mysql命令,做如下操作: 把export PATH=$PATH...2.没有启动mysql服务。 补充: 在最近的使用中,组内有的人使用linux的mysql用户启动mysql,有的人使用root用户启动mysql。...本站仅提供信息存储空间服务,拥有所有权,承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    7.2K20

    求字符串内包含重复字符的最长子串

    今天我遇到一个问题,题目描述如下:         一个字符串,求这个字符串中包含重复字符的最长子串的长度,如abba返回2,aaaaabc返回3,bbbbbbb返回1,等等上面是测试用例。...那么我解决这个问题的思路有两种: 第一种是,设一个头指针和一个尾指针,头指针指向,包含重复字符子串的第一个字符,尾指针指向包含重复子串的最后一个字符,用一个hashset保存已经出现过的字符,例如abba...,如果尾指针指向的字符,在集合中没有出现,那么将这个字符放入结合,然后尾指针向后移动,这是尾指针会移动到第二个b的位置,如果集合中已经包含了这个字符,那么用尾指针的索引减去头指针的索引,会求出一个子串的长度...第二种思路比较巧妙,思路是这样的这次要以一个hashmap作为辅助,map的key存储的是字符,value存储的是该字符当前的位置,首先设置一个头指针,指向字符串开头,那么从开始遍历字符串,如果map当中包含这个字符

    1.1K20

    全网最硬核 JVM TLAB 分析(单篇版包含额外加菜)

    由于文章很长,每个人阅读习惯不同,所以特此拆成单篇版和多篇版全网最硬核 JVM TLAB 分析(单篇版包含额外加菜) 全网最硬核 JVM TLAB 分析 1....TLAB 生命周期停止(TLAB 声明周期停止代表内存被回收,只是代表这个 TLAB 不再被这个线程私有管理)在: 当前 TLAB 不够分配,并且剩余空间小于最大浪费空间限制,那么这个 TLAB 会被退回...[image] 如果不管这些孔隙,由于 TLAB 仅线程内知道哪些被分配了,在 GC 扫描发生时返回 Eden 区,如果填充的话,外部并不知道哪一部分被使用哪一部分没有,需要做额外的检查,那么会影响...单位是字节 默认:0, 0 就是主动设置 TLAB 初始大小,而是通过 JVM 自己计算每一个线程的初始大小 举例:-XX:TLABSize=65536 7.6....线程本轮 GC 分配空间的大小包含 TLAB 中分配的和 TLAB 外分配的,从 图8、图9、图10 流程图中对于线程记录中的线程分配空间大小的记录就能看出,读取出线程分配空间大小减去上一轮 GC 结束时线程分配空间大小就是线程本轮

    1.1K40

    全网最硬核 JVM TLAB 分析(单篇版包含额外加菜)

    由于文章很长,每个人阅读习惯不同,所以特此拆成单篇版和多篇版 全网最硬核 JVM TLAB 分析(单篇版包含额外加菜) 全网最硬核 JVM TLAB 分析 1....TLAB 生命周期停止(TLAB 声明周期停止代表内存被回收,只是代表这个 TLAB 不再被这个线程私有管理)在: 当前 TLAB 不够分配,并且剩余空间小于最大浪费空间限制,那么这个 TLAB 会被退回...如果不管这些孔隙,由于 TLAB 仅线程内知道哪些被分配了,在 GC 扫描发生时返回 Eden 区,如果填充的话,外部并不知道哪一部分被使用哪一部分没有,需要做额外的检查,那么会影响 GC 扫描效率。...单位是字节 默认:0, 0 就是主动设置 TLAB 初始大小,而是通过 JVM 自己计算每一个线程的初始大小 举例:-XX:TLABSize=65536 7.6....线程本轮 GC 分配空间的大小包含 TLAB 中分配的和 TLAB 外分配的,从 图8、图9、图10 流程图中对于线程记录中的线程分配空间大小的记录就能看出,读取出线程分配空间大小减去上一轮 GC 结束时线程分配空间大小就是线程本轮

    42350
    领券