繁体   English   中英

如何将JSON存储到RavenDB?

[英]How to store JSON to RavenDB?

我想获取现有数据并将其放入RavenDB。

我现有的数据采用XML格式,因此我将其转换为JSON。

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

提前致谢!

使用RavenDB客户端向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的特定文档集合。 数据库选择和ID指定通过URL路径执行,文档集合使用元数据标题Raven-Entity-Name

您可能希望发送其他元数据标头 ,例如Raven-Clr-TypeLast-Modified但它们不是必需的。

我想你的json-data代表了你的应用程序域的数据,你想要在你的应用程序中使用具有属性的类来处理这些数据,对吗?

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

那有意义吗?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM