服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|

服务器之家 - 数据库 - Mysql - MySQL查询in操作 查询结果按in集合顺序显示

MySQL查询in操作 查询结果按in集合顺序显示

2019-11-12 16:40mysql教程网 Mysql

MySQL 查询in操作,查询结果按in集合顺序显示的实现代码,需要的朋友可以参考下。

MySQL 查询in操作,查询结果按in集合顺序显示 

复制代码代码如下:


select * from test where id in(3,1,5) order by find_in_set(id,'3,1,5'); 
select * from test where id in(3,1,5) order by substring_index('3,1,2',id,1);



偶尔看到的。。。或许有人会注意过,但我以前真不知道 
SQL: select * from table where id IN (3,6,9,1,2,5,8,7); 

这样的情况取出来后,其实,id还是按1,2,3,4,5,6,7,8,9,排序的,但如果我们真要按IN里面的顺序排序怎么办?SQL能不能完成?是否需要取回来后再foreach一下?其实mysql就有这个方法 

sql: select * from table where id IN (3,6,9,1,2,5,8,7) order by field(id,3,6,9,1,2,5,8,7); 

出来的顺序就是指定的顺序了。。。。这个,以前还真的从来没用过,偶尔看到,所以就记录了一下。一是做个笔记,二是希望可以给更多的人看到 

MySQL中NOT IN语句对NULL值的处理 

mysql> SELECT COUNT(name) FROM CVE WHERE name NOT IN ('CVE-1999-0001', 'CVE-1999-0002'); 
+-------------+ 
| count(name) | 
+-------------+ 
| 17629 | 
+-------------+ 
1 row in set (0.02 sec) 
mysql> SELECT COUNT(name) FROM CVE WHERE name NOT IN ('CVE-1999-0001', 'CVE-1999-0002', NULL); 
+-------------+ 
| count(name) | 
+-------------+ 
| 0 | 
+-------------+ 
1 row in set (0.01 sec) 
当在子查询中出现NULL的时候,结果就一定是0了。查了一下手册,确实有这样的说法。所以最后实际采用了这样的查询: 
SELECT COUNT(DISTINCT name) 
FROM CVE 
WHERE name NOT IN (SELECT cveID FROM cve_sig WHERE cveID IS NOT NULL) 
顺便提一下MySQL中正则表达式匹配的简单使用: 
SELECT COUNT(alarmID) 
FROM Alarm 
WHERE (CVE NOT RLIKE '^CVE-[0-9]{4}-[0-9]{4}$' OR CVE IS NULL) 
当然,RLIKE也可以写作REGEXP,我个人倾向于使用RLIKE,因为拼写接近LIKE,可以见名知义。 

mysql - not in 
table:info primary key(id, info_type_id) 
id, info_type_id, programme_id, episode_id 
3, 4, 382, 100034 
3, 8, 382, 100034 
4, 8, 382, 100034 
6, 8, 382, 100034 
7, 8, 382, 100034 
8, 8, 382, 100034 
9, 8, 382, 100034 
10, 8, 382, 100034 
11, 8, 382, 100034 
12, 8, 382, 100034 
13, 8, 382, 100034 
100001, 4, 382, 100034 
100002, 4, 382, 100034 

排除(id=3 && info_type_id=8) and (id=4 && info_type_id=8)這兩條記錄,即找出其它記錄 
error: select * from info where episode_id=100034 and id not in(3,4) and info_type_id not in (8); 
error result: 
id, info_type_id, programme_id, episode_id 
100001, 4, 382, 100034 
100002, 4, 382, 100034 
correct: select * from info where episode_id=100034 and (id<>3 or info_type_id<>8) and (id<>4 or info_type_id<>8); 
correct result: 
id, info_type_id, programme_id, episode_id 
3, 4, 382, 100034 
6, 8, 382, 100034 
7, 8, 382, 100034 
8, 8, 382, 100034 
9, 8, 382, 100034 
10, 8, 382, 100034 
11, 8, 382, 100034 
12, 8, 382, 100034 
13, 8, 382, 100034 
100001, 4, 382, 100034 
100002, 4, 382, 100034 
理解:id<>3 or info_type_id<>8排除掉id=3 && info_type_id=8這條記錄,當表中主鍵多于一個時,不能簡單地使用key1 NOT IN (……) AND key2 NOT IN (……) ..

延伸 · 阅读

精彩推荐
  • MysqlMySQL约束类型及举例介绍

    MySQL约束类型及举例介绍

    今天小编就为大家分享一篇关于MySQL约束类型及介绍的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来...

    no-961722019-06-19
  • MysqlMySQL数据库列的增删改实现方法

    MySQL数据库列的增删改实现方法

    这篇文章主要介绍了MySQL数据库列的增删改实现方法,结合实例形式分析了mysql数据库针对列的增加、修改、删除等相关操作sql命令及使用技巧,需要的朋友可...

    小菜鸟有大梦想2052019-06-02
  • MysqlMSSQL output使用

    MSSQL output使用

    存储过程 output 输出参数 可以是一个字符串 ...

    mssql教程网4632019-10-27
  • MysqlMySQL 数据备份与还原的示例代码

    MySQL 数据备份与还原的示例代码

    这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...

    逆心1732019-06-23
  • Mysqlmysql备份恢复mysqldump.exe几个常用用例

    mysql备份恢复mysqldump.exe几个常用用例

    mysql备份恢复mysqldump.exe几个常用用例,收集了,一个整理不错的,mysql备份与恢复用法 ...

    mysql教程网2192019-10-23
  • Mysqlmysql 中InnoDB和MyISAM的区别分析小结

    mysql 中InnoDB和MyISAM的区别分析小结

    InnoDB和MyISAM是在使用MySQL最常用的两个表类型,各有优缺点,视具体应用而定。基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持。M...

    mysql教程网3962019-10-28
  • Mysqlgetdata table表格数据join mysql方法

    getdata table表格数据join mysql方法

    今天小编就为大家分享一篇关于getdata table表格数据join mysql方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小...

    我是高手高手高高手2022019-06-04
  • MysqlMySQL里面的子查询实例

    MySQL里面的子查询实例

    最近学习php+mysql执行操作,发现了这一篇实例代码 ...

    mysql技术网1772019-10-21