任何人都可以确认存储具有空值的属性是否比不存储任何内容(即缺失值)最有效(就数据存储使用和配额而言)?
这么想似乎是合理的,在这种情况下,我想知道在使用 JDO/JPA 时如何避免存储属性值而不是空值。我只能避免使用数据存储低级 API 来存储给定的属性。
Anyone can confirm if storing a property with a null value is most effective (in terms of datastore usage and quotas) than not storing anything at all (that is, a missing value) ?
It seems reasonable to think so and, in that case, I'd like to know how to avoid storing a property value instead of a null value when using JDO/JPA. I've only been able to avoid storing a given property with the datastore low level API.
发布评论
评论(2)
我相信不存储属性将为您节省少量的磁盘配额,但我不确定这是否值得付出努力,除非这些“可选”属性的数量与“始终存在”属性的数量相比很大。
当然,您可以通过使用低级 API 创建 2 组示例数据并检查 统计 页面以查看数据存储中大小的差异。
需要注意的一个问题是,据我所知,您无法查询所有没有拥有属性的实体。
I believe that not storing a property will save you a small amount of disk quota, but I'm not sure it is worth the effort, unless the amount of these "optional" properties is large compared to the amount of "always there" properties.
Of course, you can do a simple test by creating 2 sets of sample data using the low level API, and checking the Stats page to see how the sizes differ in the datastore.
One gotcha to be aware of is that AFAIK you can't query for all entities that don't have a property.
存储 null 有其成本。
它们是 2 个写入操作,数据也很少,如果属性名称与其他实体相同,我想该名称位于字典中,并且每个属性存储一个指针来获取名称。
https://developers.google.com/appengine/docs/java/datastore /entities#Java_Understanding_write_costs
Storing null have their costs.
They are 2 writes operations and little data too, if the property name is in common with others entities, I suppose the name is in a dictionary and each property store a pointer to get the name.
https://developers.google.com/appengine/docs/java/datastore/entities#Java_Understanding_write_costs