下面的代码示例将一个简单的对象写入一个沙发床lite(版本2)数据库,然后读取所有对象。这是您可以在官方文档here中找到的内容
由于必须将每个对象的每个属性都传送到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
或许
var data = JsonConvert.SerializeToDict(item); // JsonConvert does not provide this
var doc = new MutableDocument(data);
是否存在某种优化,而首选方法是有意的?
最佳答案
人们经常问这个问题,但是Couchbase Lite实际上并没有在数据库中存储JSON字符串。它们以不同的格式存储,因此不会带来您认为的好处(需要先解析JSON,然后将其分解为其他格式)。我一直在寻求一种直接序列化类的方法,而不是通过字典对象(这似乎是这里的最终目标),但是我们的工作重点是企业客户想要的东西,而这似乎不是其中之一。请注意,要使其融入其中,需要使用C#Java和Objective-C / Swift实现。
关于c# - Couchbase Lite 2 + JsonConvert,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/49949447/