Видалити з рядків таблиці, де будь-яке поле стовпця є нульовим


12

Чи є спосіб видалити рядок із таблиці, де будь-яке поле стовпця є нульовим, не чітко вказуючи, який стовпець є нульовим?

Я використовую postgreSQL.

Ось моя схема відношення:

  Column    |  Type   |                              Modifiers                               
  --------------+---------+----------------------------------------------------------------------
  id           | integer | not null default  nextval('aurostat.visitor_center_id_seq'::regclass)
  date         | date    | 
  persons      | integer | 
  two_wheelers | integer | 
  cars         | integer | 
  vans         | integer | 
  buses        | integer | 
  autos        | integer | 

Дякую

Відповіді:


19

Я бачу два способи зробити це:

За допомогою звичайного стандартного SQL просто перелічіть усі стовпці та поєднайте це з ІЛИ:

delete from the_table
where date is null
   or persons is null
   or two_wheelers is null
   or cars is null
   or vans is null
   or buses is null
   or autos is null;

Ще одне (специфічне для Postgres) рішення - порівняння цілого ряду з NOT NULL

select *
from the_table
where the_table is not null;

поверне лише рядки, де всі стовпці не є нульовими. Ви хочете навпаки, тому вам потрібно заперечувати, що where not (the_table is not null)Умова where the_table is nullдещо інша - це лише відповідні рядки, де всі стовпці є недійсними.

delete from the_table
where not (the_table is not null);

Дякую! Я думаю, що друге рішення - це рішення, яке я шукав.
даліман


Мені дуже подобається чіткий і стислий where not (the_table is not null);підхід. Найкраще, що я можу придумати загалом SQL NATURAL JOIN.
lad2025

0

Якщо ви не хочете вказувати кожен стовпець, який ви можете використовувати NOT EXISTS ... NATURAL JOIN.

Увага! Це рішення не найкраще з точки зору продуктивності. Він повинен працювати на Oracle / PostgreSQL / SQLite / MariaDB 10.3.2 і вище.

Налаштовуючи:

CREATE TABLE the_table(
   id           integer not null 
  ,date_          date    
  ,persons       integer 
  ,two_wheelers  integer 
  ,cars          integer 
  ,vans          integer 
  ,buses         integer 
 , autos         integer 
);

INSERT INTO the_table(id, date_, persons, two_wheelers, cars, vans, buses, autos)
VALUES (1, '21/JAN/2018',1,1,1,1,1,1);

INSERT INTO the_table(id, date_, persons, two_wheelers, cars, vans, buses, autos)
VALUES (2, '21/JAN/2018',2,2,2,2,NULL,2);
INSERT INTO the_table(id, date_, persons, two_wheelers, cars, vans, buses, autos)
VALUES (3, '21/JAN/2018',3,3,3,3,NULL,NULL);

SELECT * FROM the_table;

+----+-------------+---------+--------------+------+------+-------+-------+
| id |    date_    | persons | two_wheelers | cars | vans | buses | autos |
+----+-------------+---------+--------------+------+------+-------+-------+
|  1 | 21/JAN/2018 |       1 |            1 |    1 |    1 | 1     | 1     |
|  2 | 21/JAN/2018 |       2 |            2 |    2 |    2 | null  | 2     |
|  3 | 21/JAN/2018 |       3 |            3 |    3 |    3 | null  | null  |
+----+-------------+---------+--------------+------+------+-------+-------+

І запит:

DELETE FROM the_table
WHERE NOT EXISTS (SELECT *
                  FROM the_table t1
                  NATURAL JOIN the_table t2
                  WHERE id = the_table.id);

Вихід:

+----+-------------+---------+--------------+------+------+-------+-------+
| id |    date_    | persons | two_wheelers | cars | vans | buses | autos |
+----+-------------+---------+--------------+------+------+-------+-------+
|  1 | 21/JAN/2018 |       1 |            1 |    1 |    1 |     1 |     1 |
+----+-------------+---------+--------------+------+------+-------+-------+

Демонстрація DBFiddle

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.