如何将JSON存储到RavenDB?

6

我希望将现有数据放入RavenDB中。

我的现有数据是以XML格式存储的,因此我将其转换为JSON。

接下来该怎么做呢? 我可以直接将其存储在RavenDB中吗? 还是需要创建新对象来存储它?

谢谢!


@ShaunWilson 这就是为什么它被发布为评论而不是答案的原因。 - L.B
2个回答

6
不必使用RavenDB客户端提交内容,也不必先填充域模型。这是不必要的工作,只会使数据提交/插入/迁移/导入过程变得更加复杂。
您可以直接使用HTTP API提交JSON格式的文档到RavenDB,特别是您可能希望查看“单个文档操作”主题以获取简单示例,该示例(目前)显示了使用'curl'的示例。
请考虑以下.NET代码:
var url = string.Format("http://ravendb-server:8080/databases/{0}/docs/{1}", databaseName, docId);
var webRequest = System.Net.HttpWebRequest.CreateHttp(url);
webRequest.Method = "PUT";
webRequest.ContentType = "application/json";
webRequest.Headers["Raven-Entity-Name"] = entityName;
var stream = webRequest.GetRequestStream();
using (var writer = new System.IO.StreamWriter(webRequest.GetRequestStream()))
{
    writer.Write(json);
}
var webResponse = webRequest.GetResponse();
webResponse.Close();

上面的代码片段允许您将有效的JSON文档提交到特定数据库和特定文档集合中,并指定ID。通过URL路径执行数据库选择和ID指定,并使用元数据头Raven-Entity-Name指定文档集合。
您可能希望发送其他元数据头,例如Raven-Clr-TypeLast-Modified,但这些不是必需的。

1

我猜你的json数据代表了你应用程序领域的数据,你想要有类和属性来处理你的应用程序中的数据,对吗?

如果是这样的话,你需要编写一个简单的导入应用程序,它可以填充你的领域模型一次,然后将所有对象存储为常规的RavenDB文档,就像你使用RavenDB存储任何其他对象一样。

这样说通了吗?


1
这很有道理。我最初是在寻找一种快速而简单的解决方法,但是我越深入研究,就越意识到迁移是一件麻烦的事情,现在我越细心,将来就会少遇到很多麻烦。谢谢! - ZacAttack

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接