Golang中Struct與DB中表字段通過反射自動映射 - sqlmapper


數據庫操作的情況下,我們期望在Golang中創建一個結構體(Struct)與數據庫(DB)中的一個表(Table)建立一個映射關系(Mapper),之后我們就通過操作這個Struct來操作DB中對應的Table,無須Hard-Coded sql string,無須手動維護字段映射關系。

"database/sql"只提供了最基礎的操作接口,對數據庫中一張表的增刪改查等操作,必須手動編寫sql string,

通常都是一個寫死的字符串(Hard-Code),並且需要手動維護sql中字段與Golang中的變量的映射關系,這擴展性很差,且非常容易出錯。

 

sqlmapper 就是這樣一個極簡的工具庫(簡單到只有一個go文件)。

原文地址:https://github.com/arthas29/sqlmapper

例如,DB中有一張表,結構如下:

CREATE TABLE `test_table` (
  `field_key` varchar(64) NOT NULL DEFAULT '',
  `field_one` varchar(64) DEFAULT NULL,
  `field_two` tinyint(1) DEFAULT NULL,
  `field_thr` int(12) DEFAULT NULL,
  `field_fou` float DEFAULT NULL,
  PRIMARY KEY (`field_key`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

在Golang中,創建對應的Struct,如下:

// struct in golang such as:
type DemoRow struct {
    FieldKey string  `sql:"field_key"`
    FieldOne string  `sql:"field_one"`
    FieldTwo bool    `sql:"field_two"`
    FieldThr int64   `sql:"field_thr"`
    FieldFou float64 `sql:"field_fou"`
}

然后,我們就可以通過這個Struct執行 SELECT/INSERT/UPDATE/DELETE 操作,無須硬編碼的冗長的sql string;

示例 (更多示例參見 fields_map_test.go):

// select single row
// Query by primary key (field[0])
func QueryByKey(ctx context.Context, tx *sql.Tx, db *sql.DB, fieldKey string) (
    *DemoRow, error) {

    var row DemoRow
    row.FieldKey = fieldKey
    fm, err := NewFieldsMap(table, &row)
    if err != nil {
        return nil, err
    }

    objptr, err := fm.SQLSelectByPriKey(ctx, tx, db)
    if err != nil {
        return nil, err
    }

    return objptr.(*DemoRow), nil
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM