当前位置:首页 » 编程语言 » sql替代in

sql替代in

发布时间: 2023-08-07 10:36:05

sql中用什么替代in

【where 。。in 。。 】 使用【where .... exists....】
【where 。。not in 。。 】 使用【where .... not exists....】

SELECT [字段1],[字段2],[字段3],.... FROM 表名1 AS a WHERE exists
(SELECT 1 FROM 表名2 AS b WHERE a.[字段X] = b.[字段X] )

注:1、a.[字段X] 和 b.[字段X] 是相互关联的字段。
2、SELECT 1 FROM 中数字1 是没有具体含义的你可以使用任何字段,
这里是为了减少占用系统资源建议你使用1。

Ⅱ sql 代替 in

--可试试:
select * from tableA where age = 1
union all
select * from tableA where age = 2
union all
select * from tableA where age = 6
union all
select * from tableA where age = 9
;

思路:
1.避免用in,分开来查,再用union all .
2.实际效率取决于表的实际情况:数据量,索引等。

Ⅲ sql查询有什么能替代in

in是影响SQL性能的,因为它会被解释成or,这将会舍弃使用索引。
如果有大量数据,又不想用IN,就只能在逻辑上弄清楚IN里面数据的关系,使用">","<"这种了。

Ⅳ sql模糊查询in的替代方法有什么,如下例

把num前后都拼上逗号,然后再用like
in '%,1,%' or in '%,3,%'
如果是mysql可以用find_in_set

Ⅳ sql in用exist替代问题

请参考:

--in改写exists
SELECTu.id,u.real_nameASrealName
FROMsys_useru
LEFTJOINsys_orgo
ONo.id=u.org_id
WHEREu.org_id=#{orgId}
ANDexists(select1
fromsys_user_roleur
whereur.user_id=u.id
anr.role_idIN(6,8))

Ⅵ 有没有什么好的方法代替 sql 里面的 in 功能

首先你得知道in的功能是什么。
sql里面的、on
、in
、between都有什么区别
on是关于的意思、用于两个关联的条件上面、比如
a
join
in
b
on
a.name=b.name
in是落于的意思、在你有明确的指向值的时候用。不如
in('上海,北京')
between是位于的意思、用于区域间的指向用。比如
where
age
between
18
and
24
自己好好理解

热点内容
php查询域名 发布:2025-08-25 13:21:22 浏览:106
设有递归算法 发布:2025-08-25 13:14:11 浏览:417
ftp客户端程序 发布:2025-08-25 13:03:52 浏览:920
搭建网站阿里云服务器怎么选 发布:2025-08-25 12:54:40 浏览:954
linux怎么看目录 发布:2025-08-25 12:37:57 浏览:760
加密连接不可用 发布:2025-08-25 12:33:46 浏览:387
html5存储本地存储 发布:2025-08-25 11:47:41 浏览:116
文件在线加密 发布:2025-08-25 11:29:56 浏览:87
c语言数值表 发布:2025-08-25 11:13:35 浏览:488
regexpython 发布:2025-08-25 11:13:29 浏览:33