栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

MySQL SELECT仅非空值

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MySQL SELECT仅非空值

您应该使用

IS NOT NULL
。(比较操作符
=
<>
两个给定
UNKNOWN
NULL
上表达的任一侧)。

SELECt * FROM table WHERe YourColumn IS NOT NULL;

为了完整起见,我将提到在MySQL中您还可以否定空安全相等运算符,但这不是标准的SQL。

SELECt *FROM table WHERe NOT (YourColumn <=> NULL);

编辑以反映评论。听起来您的表格可能未采用第一范式,在这种情况下,更改结构可能会使您的任务更容易。不过,还有其他几种方法可以…

SELECt val1 AS valFROM  your_tableWHERe val1 IS NOT NULLUNIOn ALLSELECt val2 FROM  your_tableWHERe val2 IS NOT NULL

上面的缺点是,它为每列多次扫描表一次。下面可能会避免这种情况,但是我还没有在MySQL中测试过。

SELECt CASE idx         WHEN 1 THEN val1         WHEN 2 THEN val2       END AS valFROM   your_table               JOIN (SELECT 1 AS idx        UNIOn ALL        SELECT 2) tHAVINg val IS NOT NULL  


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/411526.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号