Meluluskan Dokumen BSON Menggunakan Go
Apabila bekerja dengan Go dan MongoDB menggunakan pakej mgo, adalah perkara biasa untuk menghadapi cabaran semasa menghantar dokumen BSON. Artikel ini menangani satu isu sedemikian, terutamanya memfokuskan pada persoalan sama ada hendak menggunakan antara muka{} untuk dokumen BSON atau tidak.
Masalah:
Anda telah mencipta BSON dokumen, tetapi apabila cuba menghantarnya kepada fungsi dalam pakej lain yang menggunakan antara muka jenis{}, anda menghadapi ralat: "panic: Can't marshal interface {} as a BSON dokumen."
Penyelesaian:
Isu anda berpunca daripada fakta bahawa anda tidak sepatutnya membuat dokumen BSON sendiri. Sebaliknya, anda boleh mentakrifkan struct untuk mewakili skema dokumen anda dan kemudian menggunakan pakej mgo untuk mengendalikan marshaling dan unmarshaling data BSON.
Dalam account.go:
Tentukan struct yang mewakili akaun anda:
type Account struct { Id bson.ObjectId `bson:"_id"` BalanceAmount int // Other fields }
Dalam dbEngine.go:
Kemas kini fungsi Sisipan untuk menerima antara muka{} hujah:
func Insert(document interface{}) { // Establish connection, get collection session, err := mgo.Dial("localhost") c := session.DB("db_name").C("collection_name") err = c.Insert(document) // Handle any potential errors }
Dalam aplikasi utama anda:
Buat contoh struct Akaun dan masukkan ke dalam pangkalan data:
acc := Account{} acc.Id = bson.NewObjectId() acc.BalanceAmount = 3 dbEngine.Insert(&acc)
Pendekatan ini membenarkan mgo untuk mengendalikan pengekodan dan penyahkodan dokumen BSON dengan betul, menghapuskan keperluan untuk pengendalian manual.
Atas ialah kandungan terperinci Perlukah Saya Menggunakan `antara muka{}` untuk Dokumen BSON dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!