以下代码示例将一个简单的对象写入 couchbase lite(版本 2)数据库,然后读取所有对象。这个你可以在官方文档中找到here https://developer.couchbase.com/documentation/mobile/2.0/couchbase-lite/csharp.html
这是相当多的手动输入,因为每个对象的每个属性都必须传输到MutableObject
.
class Program
{
static void Main(string[] args)
{
Couchbase.Lite.Support.NetDesktop.Activate();
const string DbName = "MyDb";
var db = new Database(DbName);
var item = new Item { Name = "test", Value = 5 };
// Serialization HERE
var doc = new MutableDocument();
doc.SetString("Name", item.Name);
doc.SetInt("Value", item.Value);
db.Save(doc);
using (var qry = QueryBuilder.Select(SelectResult.All())
.From(DataSource.Database(db)))
{
foreach (var result in qry.Execute())
{
var resultItem = new Item
{
// Deserialization HERE
Name = result[DbName].Dictionary.GetString("Name"),
Value = result[DbName].Dictionary.GetInt("Value")
};
Console.WriteLine(resultItem.Name);
}
}
Console.ReadKey();
}
class Item
{
public string Name { get; set; }
public int Value { get; set; }
}
}
根据我的研究,Couchbase lite 在内部使用 JsonConvert,因此可能有一种方法可以在 JsonConvert 的帮助下简化这一切。
任何类似的东西:
var json = JsonConvert.SerializeObject(item);
var doc = new MutableDocument(json); // No overload to provide raw JSON
or maybe
var data = JsonConvert.SerializeToDict(item); // JsonConvert does not provide this
var doc = new MutableDocument(data);
是否存在某种优化,并且首选方法是故意的?
人们经常问这个问题,但 Couchbase Lite 实际上并不在数据库中存储 JSON 字符串。它们以不同的格式存储,因此这不会带来您想象的好处(JSON 需要重新解析,然后分解为其他格式)。我一直在推动一种直接序列化类的方法,而不是通过字典对象(这似乎是这里的最终目标),但我们的首要任务是企业客户想要的东西,而这似乎不是其中之一。请注意,要使其加入,需要使用 C# Java 和 Objective-C / Swift 来实现。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)