下面的代码示例将一个简单的对象写入一个沙发床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/

10-11 01:51