我想将现有的数据放入RavenDB中。如何将JSON存储到RavenDB?
我现有的数据是XML格式,因此我将它转换为JSON。
我的下一步应该是什么? 我可以将它存储在RavenDB中吗? 我是否需要创建新对象来存储它?
在此先感谢!
我想将现有的数据放入RavenDB中。如何将JSON存储到RavenDB?
我现有的数据是XML格式,因此我将它转换为JSON。
我的下一步应该是什么? 我可以将它存储在RavenDB中吗? 我是否需要创建新对象来存储它?
在此先感谢!
我想你的json-data代表你的应用程序域的数据,并且你希望有属性的类来处理你的应用程序中的数据,对吗?
如果是这样的话,您需要编写一个简单的导入应用程序,一次性填充您的领域模型,然后将所有对象存储为常规RavenDB文档,就像您使用RavenDB存储任何其他对象的方式一样。
这有道理吗?
这很有道理。我最终正在寻找一种解决这个问题的非常快速和肮脏的方法,但我越看到这一点,越是意识到迁移是一种痛苦,而现在我越来越留心,我将不再那么头疼。未来。谢谢! – ZacAttack
不一定要使用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
指定。
有additional metadata headers你可能要发送,如Raven-Clr-Type
或Last-Modified
但他们不是必需的。
@ShaunWilson这就是为什么它被张贴为评论,而不是一个答案。 –