iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql中的in使用方法是什么
  • 804
分享到

mysql中的in使用方法是什么

2024-04-02 19:04:59 804人浏览 薄情痞子
摘要

这篇文章主要讲解了“Mysql中的in使用方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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使用方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: mysql中的in使用方法是什么

本文链接: https://www.lsjlt.com/news/70203.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • mysql中的in使用方法是什么
    这篇文章主要讲解了“mysql中的in使用方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中的in使用方法是什么”吧! ...
    99+
    2024-04-02
  • mysql中select in的用法是什么
    在 MySQL 中,SELECT … IN 语句用于筛选指定列中的值是否匹配一个给定的集合中的任何一个值。语法如下: SEL...
    99+
    2024-04-02
  • MySQL中IN和NOT IN的使用方法
    这篇文章给大家分享的是有关MySQL中IN和NOT IN的使用方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.IN与NOT IN的语法格式MySQL 中的 IN 运算符用来...
    99+
    2024-04-02
  • mysql中contain的使用方法是什么
    在MySQL中,可以使用LIKE运算符来实现包含(contain)的功能。LIKE运算符用于在WHERE子句中进行模糊匹配,...
    99+
    2024-04-02
  • linux中mysql的使用方法是什么
    在Linux中使用MySQL,可以通过命令行或者图形化的方式进行操作。 命令行操作: 登录MySQL数据库:可以使用以下命令登...
    99+
    2024-04-03
    linux mysql
  • mysql中replace的使用方法是什么
    在MySQL中,REPLACE语句用于替换表中的数据。其语法如下: REPLACE INTO table_name (col...
    99+
    2024-04-28
    mysql
  • mysql中cte的使用方法是什么
    在MySQL中,CTE(Common Table Expressions)是一种常用的临时表达式,用于在查询中创建一个临时的命名结果...
    99+
    2024-04-09
    mysql
  • mysql中div的使用方法是什么
    在 MySQL 中,DIV 是一个用于执行整数除法的操作符。它将两个整数相除并返回一个整数结果,结果是将除数除以被除数的整数部分,忽...
    99+
    2024-05-10
    mysql
  • mysql中profile的使用方法是什么
    在MySQL中,PROFILE是一个用于分析查询性能的工具。它可以显示查询执行时所涉及的各种信息,包括查询优化器如何优化查询、查询执...
    99+
    2024-03-14
    mysql
  • mysql中nextval的使用方法是什么
    在MySQL中,没有内置的nextval函数来生成自增序列。通常在MySQL中,自增序列是通过使用AUTO_INCREMENT关键字...
    99+
    2024-04-09
    mysql
  • mysql中definer的使用方法是什么
    在MySQL中,DEFINER是用来指定存储过程、函数、视图的创建者的属性。通过DEFINER属性,可以指定一个用户来代替当前用户来...
    99+
    2024-04-09
    mysql
  • mysql中insert的使用方法是什么
    在MySQL中,插入数据使用INSERT INTO语句。语法格式如下: INSERT INTO table_name (column...
    99+
    2024-04-09
    mysql
  • mysql中pxc的使用方法是什么
    Percona XtraDB Cluster(PXC)是一个基于Galera集群的开源MySQL集群解决方案。它提供了高可用性、高性...
    99+
    2024-04-09
    mysql
  • mysql中export的使用方法是什么
    在MySQL中,可以使用SELECT ... INTO OUTFILE语句来导出数据到文件中。以下是一个简单的示例:...
    99+
    2024-04-09
    mysql
  • mysql中cascade的使用方法是什么
    在MySQL中,CASCADE是一种外键约束选项,用于指定当父表中的行更新或删除时,应如何处理与该行相关联的子表中的行。当使用CAS...
    99+
    2024-04-09
    mysql
  • mysql中in的作用是什么
    本篇内容介绍了“mysql中in的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • mysql中select top的使用方法是什么
    在MySQL中,没有像其他数据库系统中的"TOP"关键字来选择前几条记录。相反,可以使用LIMIT子句来实现相同...
    99+
    2024-04-09
    mysql
  • mysql中having的使用方法是什么
    在MySQL中,HAVING子句用于在对查询结果进行分组后,对分组结果进行筛选。它与WHERE子句的区别在于,WHE...
    99+
    2024-03-15
    mysql
  • mysql中rank() over的使用方法是什么
    在MySQL中,没有直接提供类似于rank() over()的函数,但可以通过使用子查询和变量来模拟实现类似功能。 下面是一个示例查...
    99+
    2024-04-02
  • mysql中limit 1的使用方法是什么
    在MySQL中,使用LIMIT 1可以限制返回的结果集中的行数为1行。这在需要仅返回结果集中的第一行时非常有用。LIMIT 1通常与...
    99+
    2024-04-09
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作