微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

来自 LiteDb 查询的任意/字符串返回值

如何解决来自 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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?