如何将JSON存储到RavenDB



我想把现有的数据放到RavenDB中。

我现有的数据是XML格式的,所以我把它转换成JSON。

下一步该做什么?我可以原样存储在RavenDB中吗?我需要创建新的对象来存储它吗?

提前感谢!

使用RavenDB Client向RavenDB提交内容并不是强制性的,也没有必要先填充域模型。这是不必要的工作,只会使数据提交/插入/迁移/导入的过程变得复杂。

您可以使用HTTP API直接向RavenDB提交JSON格式的文档,具体来说,您可能希望查看"单文档操作"主题的简单示例,其中(目前)展示了使用'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的特定数据库和特定文档集合中。数据库选择和ID指定通过URL路径执行,文档集合用元数据头Raven-Entity-Name指定。

您可能想要发送额外的元数据头,例如Raven-Clr-TypeLast-Modified,但它们不是必需的。

我假设您的json-data表示应用程序域的数据,并且您希望在应用程序中使用具有属性的类来处理该数据,对吗?

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

明白了吗?

相关内容

  • 没有找到相关文章