佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > Mysql元數(shù)據(jù)如何生成Hive建表語句注釋腳本詳解

Mysql元數(shù)據(jù)如何生成Hive建表語句注釋腳本詳解

熱門標(biāo)簽:百度競(jìng)價(jià)排名 鐵路電話系統(tǒng) 呼叫中心市場(chǎng)需求 Linux服務(wù)器 網(wǎng)站排名優(yōu)化 AI電銷 服務(wù)外包 地方門戶網(wǎng)站

前言

本文主要給大家介紹了關(guān)于Mysql元數(shù)據(jù)生成Hive建表語句注釋腳本的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹:

最近在將數(shù)據(jù)從Mysql 等其他關(guān)系型數(shù)據(jù)庫(kù) 抽取到Hive 表中時(shí),需要同步mysql表中的注釋,以下腳本可以生成hive表字段注釋修改語句。

注:其他關(guān)系型數(shù)據(jù)庫(kù)如:oracle 可以通過相同的思路,讀取元數(shù)據(jù),修改腳本語法實(shí)現(xiàn)。

使用:

在mysql元數(shù)據(jù)庫(kù):information_schema 中執(zhí)行以下語句

SELECT CONCAT('alter table ', TABLE_NAME, ' CHANGE COLUMN ', COLUMN_NAME, ' ', COLUMN_NAME, ' ', DATA_TYPE, ' comment ', '"', COLUMN_COMMENT, '"', ';')
FROM (SELECT TABLE_NAME, COLUMN_NAME, CASE WHEN DATA_TYPE = 'varchar' THEN 'string' WHEN DATA_TYPE = 'int' THEN 'int' WHEN DATA_TYPE = 'tinyint' THEN 'tinyint' WHEN DATA_TYPE = 'decimal' THEN 'double' WHEN DATA_TYPE = 'datetime' THEN 'string' WHEN DATA_TYPE = 'timestamp' THEN 'string' WHEN DATA_TYPE = 'float' THEN 'double' WHEN DATA_TYPE = 'double' THEN 'double' WHEN DATA_TYPE = 'bigint' THEN 'bigint' END AS DATA_TYPE, COLUMN_COMMENT
FROM COLUMNS
WHERE TABLE_NAME = 'o_oms_statistic_profit'
) t;

在將數(shù)據(jù)從Mysql 等其他關(guān)系型數(shù)據(jù)庫(kù) 抽取到Hive 表中時(shí),需要同步mysql表中的注釋,以下腳本可以生成hive創(chuàng)建表語句。只是生成了hive表主要的字段信息,其他信息需要手工添加。

在mysql元數(shù)據(jù)庫(kù):information_schema 中執(zhí)行以下語句

SELECT CONCAT('create table ', TABLE_NAME, '(', substring(column_info, 1, length(column_info) - 1), ')', ' comment ', '"', TABLE_COMMENT, '"', ';')
FROM (SELECT TABLE_NAME, TABLE_COMMENT, group_concat(CONCAT(COLUMN_NAME, ' ', DATA_TYPE, ' comment ', '"', COLUMN_COMMENT, '"')) AS column_info
FROM (SELECT t1.TABLE_NAME, CASE WHEN t2.TABLE_COMMENT = NULL THEN t1.TABLE_NAME ELSE t2.TABLE_COMMENT END AS TABLE_COMMENT, COLUMN_NAME, CASE WHEN DATA_TYPE = 'varchar' THEN 'string' WHEN DATA_TYPE = 'int' THEN 'int' WHEN DATA_TYPE = 'tinyint' THEN 'tinyint' WHEN DATA_TYPE = 'decimal' THEN 'double' WHEN DATA_TYPE = 'datetime' THEN 'string' WHEN DATA_TYPE = 'timestamp' THEN 'string' WHEN DATA_TYPE = 'float' THEN 'double' WHEN DATA_TYPE = 'double' THEN 'double' WHEN DATA_TYPE = 'bigint' THEN 'bigint' END AS DATA_TYPE, CASE WHEN COLUMN_COMMENT = NULL THEN COLUMN_NAME ELSE COLUMN_COMMENT END AS COLUMN_COMMENT
FROM COLUMNS t1 JOIN TABLES t2 ON t1.TABLE_NAME = t2.TABLE_NAME
WHERE t1.TABLE_NAME = 'o_oms_statistic_profit'
) t3
GROUP BY TABLE_NAME, TABLE_COMMENT
) t4;

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • MySQL常用的建表、添加字段、修改字段、添加索引SQL語句寫法總結(jié)
  • mysql建表常用sql語句個(gè)人經(jīng)驗(yàn)分享
  • mysql創(chuàng)建表的sql語句詳細(xì)總結(jié)
  • mysql建表常用的sql語句匯總

標(biāo)簽:黃山 湖南 湘潭 仙桃 衡水 蘭州 崇左 銅川

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql元數(shù)據(jù)如何生成Hive建表語句注釋腳本詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    分宜县| 额敏县| 广德县| 定结县| 罗定市| 绿春县| 吉安市| 图片| 望城县| 班戈县| 融水| 团风县| 怀柔区| 郎溪县| 望城县| 安岳县| 尼勒克县| 吉安县| 电白县| 临泽县| 酒泉市| 墨竹工卡县| 蓬莱市| 奉贤区| 兴城市| 肃宁县| 柘荣县| 寿宁县| 卢龙县| 河池市| 灌南县| 贡嘎县| 汝州市| 奉新县| 杭锦旗| 恩施市| 社会| 夏津县| 宁乡县| 乐至县| 青铜峡市|