豆爸的手册
  • 简介
  • 计算机基础
    • 浮点数的二进制表示
  • 架构设计
    • SSO
  • 服务器
    • 开启 gzip 压缩功能
    • 使用Liunx的crontab配置定时任务
    • OpenSSL生成秘钥对
    • 什么是线程安全
    • nginx基本配置与参数说明
    • Nginx日志配置参数
    • Linux命令
      • iostat
    • CGI, FashCGI, PHP-FPM
    • nginx中rewrite模块break和last原理详解
    • OOM
    • XXE漏洞的简单理解和测试
    • Apache 配置反向代理
    • 阿里云OSS STS上传配置
  • PHP
    • Laravel框架
      • Laravel 使用Apache服务器无法获取header中Authorization
      • Laravel5.1 表单数组验证
      • Laravel5 如何验证路由中的变量
      • Laravel 清除表单字段前后空白的Middleware
      • Laravel 获取执行的SQL语句
      • Laravel 将stdClass转换成Eloquent Model
      • 实际开发中如何活用 Closure
      • IoC 容器
    • Symfony框架
    • PHPExcel支持的样式
    • 计算地球上2个经纬度之间的距离
    • 创建一个自己的 Composer/Packagist 包
    • PHP Trait
    • 关于PHP浮点数
    • PHP7.2使用openssl替换mcrypt
    • rpc是什么?php中流行的rpc框架有哪些
  • MySQL
    • MySQL事务隔离级别
    • MySQL使用可重复读作为默认隔离级别的原因
    • FIND_IN_SET vs IN
    • MySQL慢查询
    • 是否使用SQL_CALC_FOUND_ROWS
    • GROUP BY性能优化
    • MySQL分页优化
    • MySQL在2个值之间获取随机数
    • MySQL数据库
      • 建表规约
      • 索引规约
      • SQL 语句
      • ORM 映射
    • MySQL 5.6 原生Online DDL解析
    • mysql使用utf8mb4经验吐血总结
  • HTTP
    • HTTP:Content-Type
    • 从HTTP到HTTPS再到HSTS
    • 主流浏览器中如何清除HSTS设置
    • 也许,这样理解HTTPS更容易
  • JavaScript
    • 跨域资源共享 CORS 详解
  • Git
    • 撤销合并
    • 从其他分支checkout文件或文件夹
    • 批量删除分支和标签
  • 前端
    • Grid布局
    • Flex布局
    • 浅谈OSS跨域功能
  • 书摘
    • 高效程序员的45个习惯
  • OpenResty
    • 新手上路
  • 敏捷开发
    • 为什么Scrum Master不叫Scrum Manager?
  • Postman
    • 使用Newman执行collections的时候,如果上传文件
    • 同步API定义到Postman
  • RESTful API最佳实践
  • 开发工具
  • 设计模式原则
  • Charles 从入门到精通
  • 阿里云OSS STS上传配置
  • 流式分页
Powered by GitBook
On this page

Was this helpful?

  1. MySQL

FIND_IN_SET vs IN

PreviousMySQL使用可重复读作为默认隔离级别的原因NextMySQL慢查询

Last updated 5 years ago

Was this helpful?

FIND_IN_SET(str,strlist)

strlist是有由英文逗号(,)分隔的字符串。如果str存在strlist的列表中,则返回str在strlist中的位置;

mysql> SELECT FIND_IN_SET('b','a,b,c,d');
+----------------------------+
| FIND_IN_SET('b','a,b,c,d') |
+----------------------------+
|                          2 |
+----------------------------+
1 row in set

如果str是一个常量字符串,strlist是一个的字符串,则FIND_IN_SET函数将使用位运算(bit arithmetic)进行优化;

如果str不存在strlist中,或者strlist为空字符串,则返回0;

mysql> SELECT FIND_IN_SET('e','a,b,c,d');
+----------------------------+
| FIND_IN_SET('e','a,b,c,d') |
+----------------------------+
|                          0 |
+----------------------------+
1 row in set

mysql> SELECT FIND_IN_SET('b','');
+---------------------+
| FIND_IN_SET('b','') |
+---------------------+
|                   0 |
+---------------------+
1 row in set

str和strlist任何一个为NULL值,则返回NULL值;

mysql> SELECT FIND_IN_SET(NULL,'a,b,c,d');
+-----------------------------+
| FIND_IN_SET(NULL,'a,b,c,d') |
+-----------------------------+
| NULL                        |
+-----------------------------+
1 row in set

mysql> SELECT FIND_IN_SET('b',NULL);
+-----------------------+
| FIND_IN_SET('b',NULL) |
+-----------------------+
| NULL                  |
+-----------------------+
1 row in set

如果第一个参数str包含英文逗号(,),则函数工作不正常;

mysql> SELECT FIND_IN_SET('b,','a,b,c,d');
+-----------------------------+
| FIND_IN_SET('b,','a,b,c,d') |
+-----------------------------+
|                           0 |
+-----------------------------+
1 row in set

expr IN (value,...)

如果expr等于IN列表中的任意值,则返回1;否则返回0;

如果所有的值都是常量,则根据expr的类型进行计算和分类。

如果IN列表全部由常量组成,则IN的速度非常快;

mysql> SELECT 2 IN (0,3,5,7);
+----------------+
| 2 IN (0,3,5,7) |
+----------------+
|              0 |
+----------------+
1 row in set

mysql> SELECT 'wefwf' IN ('wee','wefwf','weg');
+----------------------------------+
| 'wefwf' IN ('wee','wefwf','weg') |
+----------------------------------+
|                                1 |
+----------------------------------+
1 row in set

IN可以用于compare row constructors;

mysql> SELECT (3,4) IN ((1,2), (3,4));
+-------------------------+
| (3,4) IN ((1,2), (3,4)) |
+-------------------------+
|                       1 |
+-------------------------+
1 row in set

mysql> SELECT (3,4) IN ((1,2), (3,5));
+-------------------------+
| (3,4) IN ((1,2), (3,5)) |
+-------------------------+
|                       0 |
+-------------------------+
1 row in set

永远不要再IN的列表中混合加引号和不加引号的值,因为加引号和不加引号值的比较规则是不一样的。混合类型将返回不一致的结果;

SELECT val1 FROM tbl1 WHERE val1 IN (1,2,'a');
#需要使用下面的
SELECT val1 FROM tbl1 WHERE val1 IN ('1','2','a');

IN列表的具体个数由 max_allowed_packet 配置决定;

为了同SQL标准相一致,如果表达式左侧为NULL,或者找不到匹配项,或者列表中有值为NULL,则返回NULL;

mysql> SELECT NULL IN ('wee','wefwf','weg');
+-------------------------------+
| NULL IN ('wee','wefwf','weg') |
+-------------------------------+
| NULL                          |
+-------------------------------+
1 row in set

,如果查询字段有索引,并且可以使用IN的时候,请使用IN;

类型转换规则将遵循;

IN可以用在子查询中,;

SET类型
函数不会使用索引
Type Conversion in Expression Evaluation
Subqueries with ANY, IN, or SOME