309

是否可以执行仅采用 NOT NULL 值的 select 语句?

现在我正在使用这个:

SELECT * FROM table

然后我必须用 php 循环过滤掉空值。

有没有办法:

SELECT * (that are NOT NULL) FROM table

?

现在,当我选择 * 时,我得到 val1,val2,val3,null,val4,val5,null,null 等......但我只想得到结果中不为 null 的值。如果不使用循环过滤,这可能吗?

4

10 回答 10

517

你应该使用IS NOT NULL. (比较运算符=<>都在表达式UNKNOWNNULL任一侧给出。)

SELECT * 
FROM table 
WHERE YourColumn IS NOT NULL;

为了完整起见,我将提到在 MySQL 中,您还可以否定null 安全相等运算符,但这不是标准 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*/
于 2011-03-12T21:01:04.620 回答
22

您可以过滤掉特定列中包含 NULL 值的行:

SELECT col1, col2, ..., coln
FROM yourtable
WHERE somecolumn IS NOT NULL

如果要过滤掉任何列中包含 null 的行,请尝试以下操作:

SELECT col1, col2, ..., coln
FROM yourtable
WHERE col1 IS NOT NULL
AND col2 IS NOT NULL
-- ...
AND coln IS NOT NULL

更新:根据您的评论,也许您想要这个?

SELECT * FROM
(
    SELECT col1 AS col FROM yourtable
    UNION
    SELECT col2 AS col FROM yourtable
    UNION
    -- ...
    UNION
    SELECT coln AS col FROM yourtable
) T1
WHERE col IS NOT NULL

我同意 Martin 的观点,如果你需要这样做,那么你可能应该改变你的数据库设计。

于 2011-03-12T21:01:01.720 回答
13
Select * from your_table 
WHERE col1 and col2 and col3 and col4 and col5 IS NOT NULL;

这种方法的唯一缺点是你只能比较 5 列,之后结果总是错误的,所以我只比较可以是的字段NULL

于 2012-01-20T19:57:11.000 回答
8

我找到了这个解决方案:

此查询为每列选择最后一个非空值。

例子


如果你有一张桌子:

id|title|body
1 |t1   |b1
2 |NULL |b2
3 |t3   |NULL

你得到:

title|body
t3   |b2

询问


SELECT DISTINCT (

  SELECT title
  FROM test
  WHERE title IS NOT NULL 
  ORDER BY id DESC 
  LIMIT 1
) title, (

  SELECT body
  FROM test
  WHERE body IS NOT NULL 
  ORDER BY id DESC 
  LIMIT 1
) body
FROM test

我希望能帮助你。

于 2012-02-03T12:22:59.420 回答
4

以下查询为我工作

当我设置列'NULL'的默认值时

select * from table where column IS NOT NULL

当我没有设置默认值时

select * from table where column <>''
于 2018-08-05T20:11:07.190 回答
2

我使用\!MySQL 中的命令从 shell 中 grep 出 NULL 值:

\! mysql -e "SELECT * FROM table WHERE column = 123456\G" | grep -v NULL

它最适用于.my.cnf指定数据库/用户名/密码的正确位置。这样你只需select要用\! mysql eand包围你| grep -v NULL

于 2013-01-18T18:40:27.547 回答
2

MYSQL 与 JOINS 和 SELECT、INSERT INTO、DELETE 和逻辑运算符类似 OR 不为 NULL,NOT

Using IS NOT NULL On Join Conditions

 SELECT * FROM users 
 LEFT JOIN posts ON post.user_id = users.id 
 WHERE user_id IS NOT NULL;

 Using IS NOT NULL With AND Logical Operator

 SELECT * FROM users 
 WHERE email_address IS NOT NULL 
 AND mobile_number IS NOT NULL;

Using IS NOT NULL With OR Logical Operator

 SELECT * FROM users 
 WHERE email_address IS NOT NULL 
 OR mobile_number IS NOT NULL;
于 2019-06-21T05:28:05.377 回答
1

NOT NULL的,在您的查询中使用,如下所示。

SELECT * 
FROM table
WHERE col IS NOT NULL;
于 2017-06-30T00:00:52.893 回答
-2
SELECT duration,id FROM `tickets` WHERE duration !=""
于 2021-03-28T12:17:39.570 回答
-5
SELECT * FROM TABLE_NAME
where COLUMN_NAME <> '';
于 2016-03-31T16:20:33.173 回答