第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

使用 GORM 從 Postgresql 中檢索表名

使用 GORM 從 Postgresql 中檢索表名

Go
青春有我 2022-05-23 17:18:58
希望從我的 postgresql 數(shù)據(jù)庫中檢索表名?,F(xiàn)在,我知道在 Go 中你可以使用 sql 和 pq 驅(qū)動程序,但我使用 GORM 在我的 REST API 中進(jìn)行查詢。PostgreSQL 中的 table_name 類型是“information_schema.sql_identifier”。這是我試圖做的,但類型不是字符串。var tables []stringif err := db.Table("information_schema.tables").Select("table_name").Where("table_schema = ?", "public").Find(&tables).Error; err != nil {    panic(err)}
查看完整描述

1 回答

?
翻過高山走不出你

TA貢獻(xiàn)1875條經(jīng)驗(yàn) 獲得超3個贊

要使用 Gorm 將單個列值選擇到切片中,可以使用db.Pluck幫助器:


var tables []string

if err := db.Table("information_schema.tables").Where("table_schema = ?", "public").Pluck("table_name", &tables).Error; err != nil {

    panic(err)

}

TS;WM


考慮到這一點(diǎn),SELECT 語句返回一組包含一個或多個列的行。為了將它們映射到 Go 代碼,我們需要一種結(jié)構(gòu),以便 Gorm 可以了解哪個列映射到結(jié)構(gòu)的哪個字段。即使您只選擇 1 個單列,它也只是一個具有 1 個單字段的結(jié)構(gòu)。


type Table struct {

    TableName   string

    // more fields if needed...

}

所以你的輸出變量應(yīng)該是[]*Table:


var tables []*Table

if err := db.Table("information_schema.tables").Select("table_name").Where("table_schema = ?", "public").Find(&tables).Error; err != nil {

    panic(err)

}

注意:[]Table如果您不想修改切片內(nèi)的元素,也可以這樣做。


如果您不想定義結(jié)構(gòu),則可以使用該db.Pluck函數(shù),它只是此類代碼的助手:


rows, err := db.Table("information_schema.tables").Select("table_name").Where("table_schema = ?", "public").Rows()

defer rows.Close()


var tables []string

var name string

for rows.Next() {

    row.Scan(&name)

    tables = append(tables, name)

}


查看完整回答
反對 回復(fù) 2022-05-23
  • 1 回答
  • 0 關(guān)注
  • 388 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號