Массовое применение псевдонимов к столбцам таблицы в MYSQL - PullRequest
0 голосов
/ 22 декабря 2018

Я работаю со сторонней базой данных MYSQL, над которой у меня нет контроля, кроме как я могу читать из нее.Он содержит 51 таблицу с идентичной структурой столбцов, но немного другими именами.Они содержат ежедневные сводки для другого источника данных.Пример таблицы:

CREATE TABLE `archive_day_?????` (
  `dateTime` int(11) NOT NULL,
  `min` double DEFAULT NULL,
  `mintime` int(11) DEFAULT NULL,
  `max` double DEFAULT NULL,
  `maxtime` int(11) DEFAULT NULL,
  `sum` double DEFAULT NULL,
  `count` int(11) DEFAULT NULL,
  `wsum` double DEFAULT NULL,
  `sumtime` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

где ?????изменения, указывающие на тип хранимых данных.

Поле dateTime зеркально отражается во всех таблицах с полуночи каждого дня с момента запуска системы.

Я хочу создать один набор данных для всехвсе таблицы, использующие внутреннее соединение в dateTime.Но чтобы не писать

SELECT ad1.maxtime as ad1_maxtime, ad2.maxtime as ad2_maxtime... 

51 раз для 9 полей, есть ли способ массового создания псевдонимов, например

ad1.* as ad_*, ad2.* as ad_* and so on.

Я смотрел на Создать псевдонимы навалом? но, похоже, это не работает для MySQL.В конечном итоге данные используются Django ORM.

РЕДАКТИРОВАТЬ: К сожалению, Union не однозначно идентифицирует поля или группирует их вместе, например,

SELECT * FROM `archive_day_ET` UNION ALL SELECT * FROM `archive_day_inTemp`

приводит к:

Sample Union Results

1 Ответ

0 голосов
/ 22 декабря 2018

Чтобы сгенерировать строку со всеми именами полей из этих таблиц, вы можете запросить information_schema.columns

Например:

SELECT 
 GROUP_CONCAT(CONCAT(TABLE_NAME,'.`',column_name,'` AS `',column_name,'_',replace(TABLE_NAME,'archive_day_',''),'`') SEPARATOR ',\r\n')
FROM information_schema.columns
WHERE TABLE_NAME like 'archive_day_%'

Проверка на db <> fiddle здесь

И для генерации JOIN'ов вы можете использовать information_schema.tables

Например:

SELECT CONCAT('FROM (\r\n ',GROUP_CONCAT(CONCAT('SELECT `dateTime` FROM ',TABLE_NAME) SEPARATOR '\r\n UNION\r\n '),'\r\n) AS dt \r\nLEFT JOIN ',
 GROUP_CONCAT(CONCAT(TABLE_NAME,' ON ',
 TABLE_NAME,'.`dateTime` = dt.`dateTime`') SEPARATOR '\r\nLEFT JOIN ')) as SqlJoins
FROM information_schema.tables
WHERE TABLE_NAME like 'archive_day_%'

Тест на db <> fiddle здесь

Для 2 примеров таблиц они сгенерируют

archive_day_ET.`dateTime` AS `dateTime_ET`, 
archive_day_ET.`min` AS `min_ET`, 
archive_day_ET.`mintime` AS `mintime_ET`, 
archive_day_ET.`max` AS `max_ET`, 
archive_day_ET.`maxtime` AS `maxtime_ET`, 
archive_day_ET.`sum` AS `sum_ET`, 
archive_day_ET.`count` AS `count_ET`, 
archive_day_ET.`wsum` AS `wsum_ET`, 
archive_day_ET.`sumtime` AS `sumtime_ET`, 
archive_day_inTemp.`dateTime` AS `dateTime_inTemp`, 
archive_day_inTemp.`min` AS `min_inTemp`, 
archive_day_inTemp.`mintime` AS `mintime_inTemp`, 
archive_day_inTemp.`max` AS `max_inTemp`, 
archive_day_inTemp.`maxtime` AS `maxtime_inTemp`, 
archive_day_inTemp.`sum` AS `sum_inTemp`, 
archive_day_inTemp.`count` AS `count_inTemp`, 
archive_day_inTemp.`wsum` AS `wsum_inTemp`, 
archive_day_inTemp.`sumtime` AS `sumtime_inTemp`

А

FROM ( 
 SELECT `dateTime` FROM archive_day_ET
 UNION 
 SELECT `dateTime` FROM archive_day_inTemp
) AS dt
LEFT JOIN archive_day_ET ON archive_day_ET.`dateTime` = dt.`dateTime` 
LEFT JOIN archive_day_inTemp ON archive_day_inTemp.`dateTime` = dt.`dateTime`
...