优化sqlserver中的 not like

如果你想要优化一个查询,特别是当使用 NOT LIKE 来排除包含某个字符(如 ;)的记录时,确保查询能够高效执行的关键是索引和查询结构。但是,对于 NOT LIKE 操作符来说,特别是当模式以通配符 % 开头时,它通常不会利用索引(如果有一个的话),因为这样的模式匹配是非确定性的。

不过,这里有一些建议来优化或改进你的查询:

避免使用 SELECT *:只选择你真正需要的列。这可以减少数据传输的开销,特别是当表有很多列或列中有大量数据时。

sql 复制代码
SELECT Column1, Column2, ...  
FROM YourTable  

WHERE YourColumn NOT LIKE '%;%';

考虑使用 CHARINDEX:如之前提到的,CHARINDEX 函数可能是一个更好的选择,因为它在某些情况下可能更易于优化。

sql 复制代码
SELECT *  
FROM YourTable  

WHERE CHARINDEX(';', YourColumn) = 0;

创建计算列和索引(如果查询非常频繁):如果性能是一个大问题,并且你知道你的数据不会频繁更改,你可以考虑创建一个计算列,并在其上建立索引。计算列的值将是基于 YourColumn 是否包含 ; 的布尔值。

sql 复制代码
ALTER TABLE YourTable  
ADD HasSemicolon AS CASE WHEN YourColumn LIKE '%;%' THEN 1 ELSE 0 END;  
 
CREATE INDEX IX_HasSemicolon ON YourTable(HasSemicolon);  

-- 然后查询可以基于这个新列

sql 复制代码
SELECT *  
FROM YourTable  

WHERE HasSemicolon = 0;

但请注意,这种方法会增加数据插入、更新和删除的开销,因为每次更改 YourColumn 时都需要重新计算 HasSemicolon 列的值。

  1. 考虑其他数据库设计:如果 ; 字符在你的数据模型中有特殊意义,并且你经常需要基于它进行查询,那么可能需要重新考虑你的数据库设计。例如,你可以考虑将包含 ; 的数据拆分成多个行或表,或者使用一个单独的列来标记该数据是否包含 ;。

  2. 使用数据库工具:SQL Server 提供了多种工具来帮助你分析和优化查询性能,如查询执行计划、数据库引擎调优顾问(Database Engine Tuning Advisor, DTA)等。使用这些工具可以帮助你识别性能瓶颈并提供改进建议。

相关推荐
2501_941805932 小时前
在大阪智能零售场景中构建支付实时处理与高并发顾客行为分析平台的工程设计实践经验分享
数据库
李慕婉学姐3 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
珠海西格电力3 小时前
零碳园区有哪些政策支持?
大数据·数据库·人工智能·物联网·能源
数据大魔方3 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
Chasing Aurora3 小时前
数据库连接+查询优化
数据库·sql·mysql·prompt·约束
倔强的石头_4 小时前
【金仓数据库】ksql 指南(六)—— 创建与管理用户和权限(KingbaseES 安全控制核心)
数据库
小熊officer5 小时前
Python字符串
开发语言·数据库·python
渐暖°5 小时前
JDBC直连ORACLE进行查询
数据库·oracle
萧曵 丶5 小时前
Next-Key Lock、记录锁、间隙锁浅谈
数据库·sql·mysql·mvcc·可重复读·幻读
做cv的小昊6 小时前
【TJU】信息检索与分析课程笔记和练习(7)数据库检索—Ei
数据库·笔记·学习·全文检索