如何解决来自 LiteDb 查询的任意/字符串返回值
我有一个 LiteDb 数据库,我希望用户能够在该数据库上运行任意查询(以字符串形式给出;假设我们要求他们的查询也总是返回一个字符串)。不幸的是,我似乎被锁定在总是接收集合中给出的类型。例如查询
SELECT "hello"
据我所知是有效的 sql,但 LiteDb 不解析它:
new LiteDatabase(dbFile).GetCollection<MyType>().Find("SELECT 'hello'");
给出错误
位置 10 中出现意外标记 HELLO
。
当然,这个例子会失败并不意外,因为 Find
应该总是返回一个 IEnumerable<MyType>
但我找不到可以运行任意有效查询的方法。有什么好的方法可以解决这个问题吗?我明白 LiteDb 不应该是一个 sql 服务器,但我需要那种灵活性来允许用户从他们的逻辑中取回字符串;有点像允许他们对数据库进行一些编程。
解决方法
您可以在 LiteDatabase 实例中使用 Execute() 方法。它基本上会返回一个 BsonValues 集合:
var result = liteDatabase.Execute("SELECT 'John' AS Name,34 AS Age").ToEnumerable()
.SelectMany(x => ((Dictionary<string,BsonValue>)x.RawValue)
.ToDictionary(y => y.Key,y => y.Value.RawValue.ToString()));
foreach (var r in result) Console.WriteLine($"{r.Key}: {r.Value}");
但是,这带来了很大的负担,使您有义务考虑所有可能形式的复杂性。在这种简单的情况下,您将获得一个 KeyValuePair,但对于更复杂的查询,您必须处理更复杂的输出 - 因此我建议您限制自己只处理 KeyValuePairs 或类似的数据结构。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。