LoginSignup

This article is a Private article. Only a writer and users who know the URL can access it.
Please change open range to public in publish setting if you want to share this article with other users.

More than 1 year has passed since last update.

DDL作成ツール

Last updated at Posted at 2020-07-21

DDL作成ツール

【まとめ記事】
作業効率化まとめ

テーブルの項目定義書からDDLを作成します
ER図から生成するなどの場合は定義書ER図DDLといった手順になるので
本記事の対象にはなりません
##定義書のフォーマット
絶対ではないのですが、論理名, 物理名, , , null許容の順がよいかと
PK条件やリレーションは今回は割愛します
##CREATE文生成
Excelでの操作を前提としています
A1から張り付けておかないと痛い目にあいます

table_name.sql
|  テーブル名|  table_name|
|      論理名|      物理名|       型|  桁|  not null|
|         id|          id|   serial|    4|       〇|
|        氏名|       name|  varchar|  256|       〇|
 
 
 

こちらを元に変換していきます

ddl.sql
|  テーブル名|  table_name|
|      論理名|      物理名|       型|  桁|  not null| query
|         id|          id|   serial|    4|       〇| =$B3&" "&$C3&IF($D3 <> "" ,"("&$D3&")" ,"")&IF($E3=""," NOT NULL", "")
|        氏名|       name|  varchar|  256|       〇|
 
 
 

これによって
id serial(4) NOT NULL
となる
=$B3&" "&$C3&IF($D3 <> "" ,"("&$D3&")" ,"")&IF($E3="〇"," NOT NULL", "")

そして、カラムが100個の場合

="CREATE table_name ("&TEXTJOIN(", ",TRUE,F3:F102)&")"

とすれば晴れて完成である
以下でテーブル名、カラム名に論理名を付与

comment_on.sql
-- テーブル名
="COMMENT ON "&$B$1&" IS "&$A$1

-- カラム名
="COMMENT ON "&$B$1&"."&$B3&" IS "&$A3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up