能用程序去作的事,就不要用手,編寫本身的代碼生成器就是用來解放你的雙手,替你作一些重複性的工做。 上篇帖子寫了模板的基礎 go模板詳說 ,有了基礎就要作點什麼東西,把所學到的東西應用起來才能更好的進步。因而用模板寫了一個代碼生成器,用於把數據庫的錶轉換成go
的struct
,目前支持MySQL
和PostgreSQL
。這篇帖子寫實現的思路和一些具體的代碼實現。
Github地址: yggdrasill
看一下效果 html
大概的思路:git
go
的類型,若是有自定的類型要作特殊處理。這裏的元數據
也就是數據庫的表信息,因爲MySQL
和PostgreSQL
獲得表和列信息的實現方式不一樣,可是最終的數據結構是一致的,就寫了一個統一的接口來獲取元數據信息。 github
MySQL
從information_schema.tables
獲得一個數據庫下的全部表sql
select table_name from information_schema.tables where table_schema = ? and table_type = 'base table';
複製代碼
若是隻想查詢指寫的表,只需添加table_name in
查詢條件就行。
表的列信息從information_schema.columns
獲取數據庫
select column_name, is_nullable, if(column_type = 'tinyint(1)', 'boolean', data_type), column_type like '%unsigned%' from information_schema.columns where table_schema = ? and table_name = ? order by ordinal_position;
複製代碼
PostgreSQL
也是從information_schema.tables
獲取表信息,不一樣的是,不須要指定數據庫的名字,但MySql
須要,感受仍是PostgreSQL
更合理一些,由於在鏈接數據庫的dsn
裏已經指定了要操做的db
了bash
select table_name from information_schema.tables where table_schema = 'public';
複製代碼
表的列信息從information_schema.columns
獲取數據結構
select column_name, is_nullable, data_type, false
from information_schema.columns where table_schema = 'public' and table_name = $1 order by ordinal_position;
複製代碼
從數據庫裏獲取完表和列的信息後,就要把數據庫的類型轉換成go
相關的類型。ui
須要考慮的是是否有些類型要特殊處理,或自定義,特殊處理後的類型是否須要在
import
里加上具體的導入。spa
方法getGoType
把獲得的數據庫類型進行對比,返回go的類型。 code
先看一下模板的代碼,裏面的知識點上篇帖子都有說過
主要就是包名稱、是否有import、結構體信息
import
應該是會用到的,有用到時間類型就須要import time
,還有前面說的,注意自定義的類型的導入。
還有一點就是這個Tag
,因爲模板的功能還不夠豐富,就徹底用方法去實現了
看一下生成的效果
也能夠根據你的業務對這個庫進行擴展,因爲項目不讓用orm
徹底手寫sql
,我就根據本身的業務進行了擴展,把dao
層的也實現了。
必定要用模板實現麼?固然不是,能夠用你喜歡的方式去實現,只是正好閱讀了模板的官方文檔,就用他作了實現。