sql 如何查询不在这个范围内的数据,如下

2025-03-04 22:27:56
推荐回答(2个)
回答1:

用not in语句即可解决。

【SQL查询存在一个表而不在另一个表中的数据的具体方法】

例如:A、B两表,找出ID字段中,存在A表,但是不存在B表的数据。A表总共13w数据,去重后大约3W条数据,B表有2W条数据,且B表的ID字段有索引。

方法一

使用 not in ,容易理解,效率低  ~执行时间为:1.395秒~

方法二

使用 left join...on... , "B.ID isnull" 表示左连接之后在B.ID 字段为 null的记录  ~执行时间:0.739秒~

方法三

逻辑相对复杂,但是速度最快  ~执行时间: 0.570秒~

回答2:

用not in
例子
不在8-9点并且不在10-12点
你这个 不在8-9点,意思是 8:00-9:00 还是 8:00 - 8:59:59
如果是 8:00 - 8:59:59 ,那么很省事:
不知道是什么数据库
如果是 SQL Server 的话:
WHERE
DATEPART(hh,日期字段) NOT IN (8,10,11)
也就是 小时的数字,不是 8,10,11
如果是 Oracle 的话:
WHERE
TO_CHAR( 日期字段,'HH24') NOT IN ('08','10','11')
如果是 MySQL 的话,更省事了
WHERE
HOUR(日期字段) NOT IN (8,10,11)
如果是 如果是 8:00 - 9:00 ,那么很不省事:
没法简单的截取 日期字段的 小时部分,来处理了.