Вставить структуру с массивом в Mongodb с Go - PullRequest
0 голосов
/ 29 мая 2020

Я хочу вставить datastruct, как показано ниже, в MongoDB

{ "rolecode": "DHBK1_ROLE_04", "functioncodelist": [ "DHBK1_FUNC_1", "DHBK1_FUNC_2", ..... "DHBK1_FUNC_n"] "productid": "ABC_Platform", "comid": "DHBK1" }

Вот мой код:

package main
import (
    "context"
    "gopkg.in/mgo.v2"
)


func main() {
    insertObj()
}
type CompanyRoleFunction struct {
    Rolecode         string `json:"rolecode"`
    Productid        string `json:"productid"`
    Functioncodelist []string
    Comid string `json:"comid"`
}
func insertObj() {
    session, err := mgo.Dial("mongodb://casuser:Mellon@222.255.102.145:27017/users")
    if err != nil {
    panic(err)
    }
    c := session.DB("users").C("company_role_function")
    var companyRoleFunction CompanyRoleFunction
    companyRoleFunction.Rolecode = "DHBK1_ROLE_05"
    companyRoleFunction.Productid = "XYZ_Platform"
    companyRoleFunction.Comid = "DHBK1"
    err = c.Insert(companyRoleFunction)
    if err != nil {
        fmt.Println(err)
    }
}

Мой код запущен, но он только вставляет структуру вот так (конечно, потому что я не знаю, как обрабатывать массив Functioncodelist)

[! [введите здесь описание изображения] [1]] [1]

Вот мои данные, Надеюсь вставить

{"_id":{"$oid":"5ed0c2e2402a000037004c84"},"rolecode":"DHBK1_ROLE_07","functioncodelist":["DHBK1_FUNC_1","DHBK1_FUNC_2"],"productid":"ABC_Platform","comid":"DHBK1"}

1 Ответ

0 голосов
/ 29 мая 2020

Он не отображается в базе данных, потому что вставленный вами документ не содержал никаких значений. Задайте значение в коде go, и оно должно отлично отображаться в базе данных, если я неверно истолковал ваш вопрос.

...
type Functioncode string
...
companyRoleFunction.Functioncodelist = make(map[string]Functioncode)
...
companyRoleFunction.Functioncodelist["foo"] = "bar"
...

См. https://tour.golang.org/moretypes/19 для быстрого ознакомления с go карт.

...