数据库in的用法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据库in的用法相关的知识,希望对你有一定的参考价值。

参考技术A

  数据库in的用法的用法你知道吗?下面我就跟你们详细介绍下数据库in的用法的用法,希望对你们有用。

  数据库in的用法的用法如下:

  mysql IN 语法

  IN 运算符用于 WHERE 表达式中,以列表项的形式支持多个选择,语法如下:

  WHERE column IN (value1,value2,...)

  WHERE column NOT IN (value1,value2,...)

  当 IN 前面加上 NOT 运算符时,表示与 IN 相反的意思,即不在这些列表项内选择。

  IN 使用实例

  选取 uid 为 2、3、5 的用户数据:

  SELECT * FROM user WHERE uid IN (2,3,5)

  返回查询结果如下:

  uid

  username

  password

  email

  regdate

  2 小明 a193686a53e4de85ee3f2ff0576adf01 xiao@163.com 1278063917

  3 Jack 0193686a35e4de85ee3f2ff0567adf490 jack@gmail.com 1278061380

  5 5idev a193686a53e4de85ee3f2ff0576adf01 5idev@5idev.com 1291107029

  IN 子查询

  更多情况下,IN 列表项的值是不明确的,而可能是通过一个子查询得到的:

  SELECT * FROM article WHERE uid IN(SELECT uid FROM user WHERE status=0)

  在这个 SQL 例子里,我们实现了查出所有状态为 0 的用户(可能是被禁止)的所有文章。首先通过一个查询得到所有所有 status=0 的用户:

  SELECT uid FROM user WHERE status=0

  然后将查询结果作为 IN 的列表项以实现最终的查询结果,注意在子查询中返回的结果必须是一个字段列表项。

  IN 运算符补充说明

  IN 列表项不仅支持数字,也支持字符甚至时间日期类型等,并且可以将这些不同类型的数据项混合排列而无须跟 column 的类型保持一致:

  SELECT * FROM user WHERE uid IN(1,2,'3','c')

  一个 IN 只能对一个字段进行范围比对,如果要指定更多字段,可以使用 AND 或 OR 逻辑运算符:

  SELECT * FROM user WHERE uid IN(1,2) OR username IN('admin','5idev')

  使用 AND 或 OR 逻辑运算符后,IN 还可以和其他如 LIKE、>=、= 等运算符一起使用。

  关于 IN 运算符的效率问题

  如果 IN 的列表项是确定的,那么可以用多个 OR 来代替:

  SELECT * FROM user WHERE uid IN (2,3,5)

  // 等效为:

  SELECT * FROM user WHERE (uid=2 OR aid=3 OR aid=5)

  一般认为,如果是对索引字段进行操作,使用 OR 效率高于 IN,但对于列表项不确定的时候(如需要子查询得到结果),就必须使用 IN 运算符。另外,对于子查询表数据小于主查询的时候,也是适用 IN 运算符的。

在Mysql5.0 中In 用法的疑惑

SELECT * FROM A where A.bigclass in(select arrchild from B) 这样子为什么查不到数据,但是写成
SELECT * FROM A where A.bigclass in(1,2,35,5) 这样子就可以。

注:select arrchild from B 的查询结果是一条记录内容是一字符串(1,2,35,5)

select arrchild from B 的查询结果是一条记录内容是一字符串(1,2,35,5)
这种情况下,

执行
SELECT * FROM A where A.bigclass in(select arrchild from B)
相当于执行
SELECT * FROM A where A.bigclass in( '1,2,35,5' )
结果肯定是没有。

假如你的
select arrchild from B 的查询结果是
1
2
35
4
这样的 4 行数据。
那么
SELECT * FROM A where A.bigclass in(select arrchild from B)
就等价于
SELECT * FROM A where A.bigclass in(1,2,35,5)

如果
select arrchild from B 的查询结果是一条记录内容是一字符串(1,2,35,5)
又要实现
SELECT * FROM A where A.bigclass in(1,2,35,5) 的效果。

一个变通的办法是:
SELECT * FROM A
where
INSTR ( CONCAT ( ',' , (select arrchild from B) , ',' ),
CONCAT (',' , A.bigclass , ',' ) ) > 0追问

啊,我明白了
SELECT * FROM A where A.bigclass in(1,2,35,5) 这里面的(1,2,35,5) 相当于多个值。
而(select arrchild from B 的查询结果有且只有一条记录且内容是就是 "1,2,35,5")相当于一个值。

参考技术A 使用的时候他会将select arrchild from B查询出来的每条记录当做一个整体
SELECT * FROM A where A.bigclass in(select arrchild from B) 这个相当于
SELECT * FROM A where A.bigclass in( ‘1,2,35,5’ ) ----所以查不出来
------------------------------
arrchild
1,2,35,5
------------------------------

想要下面的结果,
select arrchild from B这个查询出来的结果要是这样的
----------------------------------------
arrchild
1
2
35
5
----------------------------------------追问

注:select arrchild from B 的查询结果有且只有一条记录且内容是就是 "1,2,35,5"

参考技术B 不是查不到,应该是速度很慢。如果可以的话尽量使用=来代替in语句,myql的in语句貌似没有优化过,效率很低的

以上是关于数据库in的用法的主要内容,如果未能解决你的问题,请参考以下文章

sql in用法

oracle中in和out用法

MYSQL 查询语句中in的用法

exists和in的用法

请问一下,那位高手知道数据库语句中 in ,on ,with 等关键字的用法啊,求解.......

SQL中IN和EXISTS用法的区别