And*_*ndy 13 nosql document-database ravendb
我正在尝试迁移现有的Web应用程序以使用RavenDB.
我目前在我的Web应用程序中有页面,允许您根据查询字符串中的id查看Categories,SubCategories和Resources.
但是我注意到RavenDB为聚合根生成了id,但是没有为子实体生成id.
我不认为子类别是聚合根(类别具有子类别),因此我将其作为我的类别文档的子文档.
我错误地将其作为子文档,因为我通过查询字符串传入的id直接访问它?但如果没有,我应该如何访问单个SubCategories,因为RavenDB似乎不为非聚合根的实体生成id?
我遇到了这个问题,但是对于让文档生成ID感到不舒服,因为我觉得它不是线程安全的,特别是对于基于Web的环境.
最终我决定让服务器使用GenerateDocumentKey方法为我生成id,如下所示:
using (var session = Store.OpenSession())
{
if(category.SubCategories != null)
{
var newSubCategories = data.BankAccounts.Where(x => string.IsNullOrEmpty(x.Id));
foreach (var sc in newSubCategories)
sc.Id = session.Advanced.Conventions.GenerateDocumentKey(sc);
}
session.Store(data);
session.SaveChanges();
}
Run Code Online (Sandbox Code Playgroud)
这样我就允许数据库生成子Id,并且可以确保我不必在实际类本身中满足竞争条件等.
| 归档时间: |
|
| 查看次数: |
1897 次 |
| 最近记录: |