亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

無法使用 Golang 從 SQL Server 查詢數據 - 出現錯誤“無效的對象名稱”

無法使用 Golang 從 SQL Server 查詢數據 - 出現錯誤“無效的對象名稱”

Go
守候你守候我 2023-08-14 16:53:42
我正在嘗試使用 Golang 和 GORM 從 SQL Server 查詢數據。但我收到以下錯誤:-DB Connection: &{{{0 0} 0 0 0 0} <nil> <nil> 0 0xc0000a4480 false 0 {0xc0000e5db0} <nil> {{0 0} {<nil>} map[] 0} 0xc00004c5b0 0xaccbe0 0xc00014d0a0 false <nil>}HasTable- Currency: true{CurrencyId:0 Code: Description:}[35m(C:/Users/RahulBFL/Documents/architechbc/dot net/GORM/main.go:26)[0m[33m[2019-12-27 15:56:13][0m [31;1m mssql: Invalid object name 'currencies'. [0m我的表架構如下所示:-     CurrencyCurrencyId    intCode          charDescription   varchar在 SSMS 上,我可以使用以下命令成功查詢表select * from IMBookingApp.dbo.Currency我的 Golang 代碼package mainimport (    "fmt"    "github.com/jinzhu/gorm"    _ "github.com/jinzhu/gorm/dialects/mssql")type Currency struct {    CurrencyId  int    Code        string    Description string}func main() {    db, err := gorm.Open("mssql", "sqlserver://USERNAME:PASSWORD@Endpoint:1433?database=DATABASENAME&Initial+Catalog=SCHEMA_NAME")    if err != nil {        fmt.Println("Connection Error:", err)    }   fmt.Println("DB Connection", db)    fmt.Println("HasTable- Currency:", db.HasTable("ClientUser"))    var Currency Currency    db.Find(&Currency)    fmt.Printf("%+v\n", Currency)    defer db.Close()}我不明白為什么我收到錯誤 - 無效的對象名稱“貨幣”。盡管架構中沒有貨幣,但只有貨幣。任何幫助將不勝感激。
查看完整描述

1 回答

?
慕俠2389804

TA貢獻1719條經驗 獲得超6個贊

如果您檢查錯誤,Invalid object name 'currencies'它會嘗試查找名為 的表currencies。默認情況下,gorm 將表名稱復數。如果您想要自定義表名稱,可以如下定義:


func (Currency) TableName() string {

    return "currency"

}

或者您可以使用以下命令全局禁用它:


db.SingularTable(true)

所以你的樣本應該是這樣的:


type Currency struct {

    CurrencyId  int

    Code        string

    Description string

    CreateDate  time.Time

}


func (Currency) TableName() string {

    return "currency"

}



func main() {

    db, err := gorm.Open("mssql", "sqls*******talog=dbo")


    db.SingularTable(true)


    fmt.Println("db.HasTable: Currency:", db.HasTable("ClientUser"))


    var Currency []Currency 


    db.Find(&Currency)


    ....

}


查看完整回答
反對 回復 2023-08-14
  • 1 回答
  • 0 關注
  • 234 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號