我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中的in使用方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中的in使用方法是什么

这篇文章主要讲解了“mysql中的in使用方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中的in使用方法是什么”吧!

mysql中in配合where表达式使用,用于查询某个范围内的数据,语法为“select * from where field in (value)”或者“select * from where field not in (value)”。

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql中in的用法是什么

一、基础用法

mysql中in常用于where表达式中,其作用是查询某个范围内的数据。

select * from where field in (value1,value2,value3,…)

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

select * from where field not in (value1,value2,value3,…)
二、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的子查询中常常会遇到查询效率太低问题,解决方法如下:

1、仍使用in子查询,多查询一次

SELECT * FROM basic_zdjbxx WHERE suiji IN ( SELECT zdcode FROM ( SELECT zdcode FROM basic_h WHERE zdcode != "" ) AS h )

2、使用LEFT JOIN

SELECT zd.* FROM ( SELECT DISTINCT zdcode FROM basic_h WHERE zdcode != "" ) AS h LEFT JOIN basic_zdjbxx zd ON zd.suiji = h.zdcode
三、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','manong')

使用 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)

一般认为:

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

2.in或or在字段没有添加索引的情况下,所连接的字段越多(1 or 2 or 3 or 4 or…),or比in的查询效率低很多。

感谢各位的阅读,以上就是“mysql中的in使用方法是什么”的内容了,经过本文的学习后,相信大家对mysql中的in使用方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中的in使用方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中contract的使用方法是什么

在MySQL中,可以通过以下步骤来使用contract:创建一个新的contract表格:首先使用CREATE TABLE语句创建一个新的表格,例如:CREATE TABLE contract (id INT PRIMARY KEY,n
mysql中contract的使用方法是什么
2024-05-23

mysql中nextval的使用方法是什么

在MySQL中,没有内置的nextval函数来生成自增序列。通常在MySQL中,自增序列是通过使用AUTO_INCREMENT关键字在表字段上来实现的。示例:CREATE TABLE users (id INT AUTO_INCREME
mysql中nextval的使用方法是什么
2024-04-09

mysql中pxc的使用方法是什么

Percona XtraDB Cluster(PXC)是一个基于Galera集群的开源MySQL集群解决方案。它提供了高可用性、高性能和容错容忍性,可以用于构建可扩展的MySQL集群。要使用Percona XtraDB Cluster(P
mysql中pxc的使用方法是什么
2024-04-09

mysql中cte的使用方法是什么

在MySQL中,CTE(Common Table Expressions)是一种常用的临时表达式,用于在查询中创建一个临时的命名结果集,以便在后续的查询中引用它。CTE可以提高查询的可读性和性能。使用CTE的一般语法如下所示:WITH
mysql中cte的使用方法是什么
2024-04-09

mysql中cascade的使用方法是什么

在MySQL中,CASCADE是一种外键约束选项,用于指定当父表中的行更新或删除时,应如何处理与该行相关联的子表中的行。当使用CASCADE时,当父表中的行更新或删除时,子表中的相关行也将更新或删除。使用CASCADE的方法如下:在创建外
mysql中cascade的使用方法是什么
2024-04-09

mysql中export的使用方法是什么

在MySQL中,可以使用SELECT ... INTO OUTFILE语句来导出数据到文件中。以下是一个简单的示例:SELECT * INTO OUTFILE 'C:/Users/User/Desktop/result.txt&
mysql中export的使用方法是什么
2024-04-09

mysql中definer的使用方法是什么

在MySQL中,DEFINER是用来指定存储过程、函数、视图的创建者的属性。通过DEFINER属性,可以指定一个用户来代替当前用户来创建这些对象,从而控制对象的访问权限。可以使用以下语法来指定DEFINER属性:CREATE DEFIN
mysql中definer的使用方法是什么
2024-04-09

mysql中insert的使用方法是什么

在MySQL中,插入数据使用INSERT INTO语句。语法格式如下:INSERT INTO table_name (column1, column2, column3, ...)VALUES (value1, value2, valu
mysql中insert的使用方法是什么
2024-04-09

mysql中profile的使用方法是什么

在MySQL中,PROFILE是一个用于分析查询性能的工具。它可以显示查询执行时所涉及的各种信息,包括查询优化器如何优化查询、查询执行的时间、扫描的行数等等。要使用PROFILE,可以在执行查询时在查询前面添加关键字PROFILE,例如:
mysql中profile的使用方法是什么
2024-03-14

linux中mysql的使用方法是什么

在Linux中使用MySQL,可以通过命令行或者图形化的方式进行操作。命令行操作:登录MySQL数据库:可以使用以下命令登录到MySQL数据库,需要输入密码:mysql -u username -p创建数据库:可以使用以下命令创建数据库:C
linux中mysql的使用方法是什么
2024-04-03

mysql中div的使用方法是什么

在 MySQL 中,DIV 是一个用于执行整数除法的操作符。它将两个整数相除并返回一个整数结果,结果是将除数除以被除数的整数部分,忽略小数部分。例如:SELECT 5 DIV 2; -- 结果为2SELECT 10 DIV 3; --
mysql中div的使用方法是什么
2024-05-10

mysql中join的使用方法是什么

在MySQL中,JOIN用于从多个表中检索相关数据。JOIN子句用于将两个或多个表中的行连接在一起,根据这些表之间的关系。JOIN子句可以根据不同的关键字将表连接在一起,包括INNER JOIN、LEFT JOIN、RIGHT JOIN和F
mysql中join的使用方法是什么
2024-05-21

mysql中replace的使用方法是什么

在MySQL中,REPLACE语句用于替换表中的数据。其语法如下:REPLACE INTO table_name (column1, column2, ...)VALUES (value1, value2, ...);或者可以使用UPD
mysql中replace的使用方法是什么
2024-04-28

mysql中having的使用方法是什么

在MySQL中,HAVING子句用于在对查询结果进行分组后,对分组结果进行筛选。它与WHERE子句的区别在于,WHERE子句用于筛选行,而HAVING子句用于筛选分组。HAVING子句的一般语法如下:SELECT 列1, 列2, ...
mysql中having的使用方法是什么
2024-03-15

编程热搜

目录