从Go中的Python项目加载数据存储区实体会导致嵌套的结构切片切片错误
作者:互联网
我出于性能原因在Go中的Google AppEngine项目中编写了一个模块,但需要能够从我在数据存储区中的一些实体中读取.我写了Go代码,以便能够读取我在Python中构建的实体,但是我收到以下错误:
数据存储:展平嵌套结构导致切片:字段“消息”
Python中的模型定义:
class ModelB(ndb.Model):
msg_id = ndb.StringProperty(indexed=False)
cat_ids = ndb.StringProperty(repeated=True, indexed=False)
list_ids = ndb.StringProperty(repeated=True, indexed=False)
default_list_id_index = ndb.IntegerProperty(indexed=False)
class ModelA(ndb.Model):
date_join = ndb.DateTimeProperty(auto_now_add=True)
name = ndb.StringProperty()
owner_salutation = ndb.StringProperty(indexed=False)
owner_email_address = ndb.StringProperty()
logo_url = ndb.StringProperty(indexed=False)
...
messages = ndb.LocalStructuredProperty(ModelB, name='bm', repeated=True)
在Go:
type ModelB struct {
MessageID string `datastore:"msg_id,noindex"`
CategoryIDs []string `datastore:"cat_ids,noindex"`
ListIDs []string `datastore:"list_ids,noindex"`
DefaultListIDIndex int `datastore:"default_list_id_index,noindex"`
}
type ModelA struct {
DateJoin time.Time `datastore:"date_join,"`
Name string `datastore:"name,"`
OwnerSalutation string `datastore:"owner_salutation,noindex"`
OwnerEmailAddress string `datastore:"owner_email_address,"`
LogoURL string `datastore:"logo_url,noindex"`
Messages []ModelB `datastore:"bm,"`
}
我有什么问题吗?只是Go与Python模型定义之间的功能不兼容?
尝试解码ModelB
重新定义ModelA如下:
import pb "appengine_internal/datastore"
import proto "code.google.com/p/goprotobuf/proto"
type ModelA struct {
DateJoin time.Time `datastore:"date_join,"`
Name string `datastore:"name,"`
OwnerSalutation string `datastore:"owner_salutation,noindex"`
OwnerEmailAddress string `datastore:"owner_email_address,"`
LogoURL string `datastore:"logo_url,noindex"`
Messages []ModelB `datastore:"-"`
}
// Load is implemented for the PropertyLoaderSaver interface.
func (seller *ModelA) Load(c <-chan datastore.Property) error {
f := make(chan datastore.Property, 100)
for p := range c {
if p.Name == "bm" {
var val pb.EntityProto
err := proto.Unmarshal([]byte(p.Value.(string)), &val)
if err != nil {
return err
}
//TODO: Store result as a new ModelB
} else {
f <- p
}
}
close(f)
return datastore.LoadStruct(seller, f)
}
但是我收到以下错误:
proto:未设置必填字段“{Unknown}”
解决方法:
Go数据存储区包不支持这样的两层切片.只要ModelB不包含任何切片,您就可以拥有[] ModelB.或者,您可以在ModelA中使用ModelB,而ModelB可以在其中包含切片.但你不能让[] ModelB和ModelB都有切片.有关错误情况,请参阅the code.你的选择:
>不要在Go中这样做
>编写自己的数据存储区解串器来处理这种情况 – 这可能很难
>更改python数据结构以满足Go要求并重写数据
标签:python,go,google-app-engine,app-engine-ndb 来源: https://codeday.me/bug/20190612/1226839.html