mysql select不为空_MySQL SELECT只能不为空值

你应该使用IS NOT NULL。 (比较运算符=和都在表达式的任一侧给出UNKNOWN为NULL。)

SELECT *

FROM table

WHERE YourColumn IS NOT NULL;

为了完整性,我会提到,在MySQL中,你也可以否定null safe equality operator,但这不是标准的SQL。

SELECT *

FROM table

WHERE NOT (YourColumn <=> NULL);

已编辑以反映评论。听起来你的表可能不是第一正常形式,在这种情况下更改结构可能会使您的任务更容易。几个其他的方式做它虽然…

SELECT val1 AS val

FROM your_table

WHERE val1 IS NOT NULL

UNION ALL

SELECT val2

FROM your_table

WHERE val2 IS NOT NULL

/*And so on for all your columns*/

上述的缺点是它为每一列扫描表多次一次。这可能可以通过下面但是我没有在MySQL中测试这个。

SELECT CASE idx

WHEN 1 THEN val1

WHEN 2 THEN val2

END AS val

FROM your_table

/*CROSS JOIN*/

JOIN (SELECT 1 AS idx

UNION ALL

SELECT 2) t

HAVING val IS NOT NULL /*Can reference alias in Having in MySQL*/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值