JSON

使用Couchbase存储Non-JSON数据

字号+ 作者:H5之家 来源:H5之家 2016-10-18 16:01 我要评论( )

如果你使用 Couchbase服务器 作为存储JSON文档的文档数据库的话,我相信 它的大部分功能都能得以发挥。比如,你可以使用 N1QL !然而,有些时候你需要使用Couchb

> 脚本语言 > >

使用Couchbase存储Non-JSON数据 2016-10-12 17:19 出处:清屏网 人气: 

如果你使用 Couchbase服务器 作为存储JSON文档的文档数据库的话,我相信 它的大部分功能都能得以发挥。比如,你可以使用 N1QL !然而,有些时候你需要使用Couchbase存储其它的数据。在这篇博客中,我将向你展示如何将XML和二进制数据存储到Couchbase中。我会使用.NET的SDK,但我相信其他的SDK也支持这些操作。

存储JSON文档回顾

快速地回顾一下在Couchbase中存储JSON文档的知识。一旦你有了一个bucket,你就可以使用Insert/Upsert来创建/更新一个文档,然后使用Get将文档读取出来。使用.NET SDK,你可以按照所定义的类型自动处理序列化。

//创建文档 bucket.Insert<MyType>("JSON_" + guid, new MyType { Foo = "BarJSON"}); //读取文档并显示出来 var jsonBackOut = bucket.Get<MyType>("JSON_" + guid).Value; Console.WriteLine($"JSON document: {jsonBackOut.Foo}");

存储XML

存储XML需要多做一点工作。首先,我使用XmlSerializer将对象序列化为XML字符串。然后,我将该值Insert成为一个字符串。为了将其读取出来,我再次使用xmlseralizer将其从字符串转换成为一个类型。

var xmlo = new MyType {Foo = "BarXML"}; var xml = new XmlSerializer(xmlo.GetType()); using (var textWriter = new StringWriter()) { xml.Serialize(textWriter, xmlo); bucket.Insert<string>("XML_" + guid, textWriter.ToString()); } //读取, 反序列化, var xmlBackOut = bucket.Get<string>("XML_" + guid).Value; using (var reader = new StringReader(xmlBackOut)) { var xmlObject = (MyType)xml.Deserialize(reader); Console.WriteLine($"XML: {xmlObject.Foo}"); } 存储一个字节数组序列化

接下来,我要将对象序列化为一个byte数组。不像JSON和XML,存储成一个字节数组意味着只能将该对象再次序列化成为.NET对象。

该过程类似于XML,除了Insert和Get定义的byte[]而不是string,并且我使用BinaryFormatter代替XmlSerializer。

var formatter = new BinaryFormatter(); using (var ms = new MemoryStream()) { formatter.Serialize(ms, new MyType { Foo = "BarDotNET"}); bucket.Insert<byte[]>("byte_" + guid, ms.ToArray()); } //将字节读取出来,反序列化,并显示对象 var bytesBackOut = bucket.Get<byte[]>("byte_" + guid).Value; using (var stream = new MemoryStream(bytesBackOut)) { var bytesObject = (MyType)formatter.Deserialize(stream); Console.WriteLine($".NET: {bytesObject.Foo}"); }

运行终端示例程序 ( 源代码在Github ) produces:

当你运行上面的示例代码后,你会看到Couchbase控制台的显示如下:

non-JSON文档会和JSON文档存在同一个bucket中。但正如你所看到的,Couchbase服务器并不知道如何解释它们。所以,你不能对这些文件执行大多数的N1QL操作。你不能像JSON文档那样索引它们的值。并且,在使用.NET字节数组的情况下,一个非.NET程序将根本无法解释他们。

如果你能将数值存储到JSON文档中,我推荐你这样做。但是,Couchbase服务器为你提供了存储其它类型数值的灵活性。


分享给小伙伴们:

本文标签: Couchbase,Non-JSON/">Couchbase,Non-JSON

相关文章

发表评论愿您的每句评论,都能给大家的生活添色彩,带来共鸣,带来思索,带来快乐。

  • 本类最热新闻

     

    1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

    相关文章
    • Query JSON Using SQL With Couchbase Query Workbench

      Query JSON Using SQL With Couchbase Query Workbench

      2016-01-17 12:53

    网友点评
    .