Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Usuń wszystkie daty zerowe z bazy danych MySQL we wszystkich tabelach

Aby zmienić istniejące wartości, możesz użyć zapytania takiego:

UPDATE tablename SET date_column = '1900-01-01' WHERE date_column = '0000-00-00';

Jeśli chcesz zautomatyzować zapytanie UPDATE, możesz użyć przygotowanej instrukcji:

SET @sql_update=CONCAT_WS(' ', 'UPDATE', CONCAT(_schema, '.', _table),
                               'SET', _column, '=', '\'1900-01-01\'',
                               'WHERE', _column, '=', '\'0000-00-00\'');

PREPARE stmt FROM @sql_update;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

I możesz przejść przez wszystkie kolumny we wszystkich tabelach w bieżącym schemacie, które są zadeklarowane jako data:

SELECT
  table_schema,
  table_name,
  column_name
FROM
  information_schema.columns
WHERE
  table_schema=DATABASE() AND data_type LIKE 'date%'

Aby przejść przez wszystkie kolumny, możesz użyć procedury składowanej:

DELIMITER //
CREATE PROCEDURE update_all_tables() BEGIN
  DECLARE done BOOLEAN DEFAULT FALSE;
  DECLARE _schema VARCHAR(255);
  DECLARE _table VARCHAR(255);
  DECLARE _column VARCHAR(255);
  DECLARE cur CURSOR FOR SELECT
                           CONCAT('`', REPLACE(table_schema, '`', '``'), '`'),
                           CONCAT('`', REPLACE(table_name, '`', '``'), '`'),
                           CONCAT('`', REPLACE(column_name, '`', '``'), '`')
                         FROM
                           information_schema.columns
                         WHERE
                           table_schema=DATABASE() AND data_type LIKE 'date%';

  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done := TRUE;

  OPEN cur;

  columnsLoop: LOOP
    FETCH cur INTO _schema, _table, _column;
    IF done THEN
      LEAVE columnsLoop;
    END IF;   

    SET @sql_update=CONCAT_WS(' ', 'UPDATE', CONCAT(_schema, '.', _table),
                                   'SET', _column, '=', '\'1900-01-01\'',
                                   'WHERE', _column, '=', '\'0000-00-00\'');

    PREPARE stmt FROM @sql_update;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;

  END LOOP columnsLoop;

  CLOSE cur;
END//
DELIMITER ;

Zobacz przykład tutaj .



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Pomoc do zapytań SQL - dwa warunki gdzie są w warunku sprzężenia

  2. Ignorowanie roku w zapytaniu SQL z zakresem dat

  3. Skuteczne ustalanie, czy firma jest otwarta, czy nie, na podstawie godzin pracy sklepu

  4. Wybierz dostępne pokoje między dwoma terminami

  5. Usuń zduplikowane wiersze o liczbie większej niż 1 w mysql