【问题标题】:UWP Custom Sqlite Query to JSONUWP 自定义 Sqlite 查询到 JSON
【发布时间】:2021-03-04 11:55:52
【问题描述】:

我正在寻找一种方法来执行自定义 SQL 查询并以 JSON 格式提供结果。通常您必须为查询结果提供一个类,例如

var query = dbConn.Query<ClassTypes>("Select a as key, b as value FROM table WHERE id = ?", new object[] { ObjectID });

但就我而言,我不知道 SQL 语句,因为它是由来自 Webview 的外部 JavaScript 提供的。

此 Webview 可能会要求我的应用程序执行

Select a.col1 as foo,b.col1, a.col2 FROM table1 a INNER JOIN table2 b ON a.id=b.aid

并希望我回来:

foo:xxx
col2:yyy

SQL 语句“询问”哪些列是完全免费的,或者使用了哪些别名,我只想执行语句返回键值对,其中包含别名或列名以及 JSON 中的值(对于每个行)。

所以我无法为查询准备自定义类,因为我不知道 SQL 查询的格式。

有人有想法吗?

【问题讨论】:

  • 你用Microsoft.Data.Sqlite查询数据库对吗?
  • 您可能想提一下您使用的Query 方法是什么?支持什么返回类型/重载等?它看起来像 Dapper,但我无法确认。
  • 如果答案已经解决了您的问题,请mark它被接受

标签: c# uwp sqlite.net


【解决方案1】:

我只想执行一个返回键值对的语句,其中包含别名或列名以及 JSON 中的值(对于每一行)。

对于您的场景,您可以使用SqlDataReader 接近,SqlDataReader 包含可用于获取列名作为键的GetName 方法,它还包含可以检索列值的GetSqlValue 方法。如果无法确认字段数,也可以使用FieldCount 获取当前读者的字段数

例如

using (SqlConnection conn = new SqlConnection(connectionString))
{
    conn.Open();
    if (conn.State == System.Data.ConnectionState.Open)
    {
        using (SqlCommand cmd = conn.CreateCommand())
        {
            cmd.CommandText = GetProductsQuery;
            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                var list = new List<Dictionary<string, object>>();
                while (reader.Read())
                {
                    var dict = new Dictionary<string, object>();
                    var i = 0;
                    do
                    {
                        var key = reader.GetName(i);
                        var value = reader.GetSqlValue(i);
                        dict.Add(key, value);
                        i++;
                    } while (i < reader.FieldCount);
                    list.Add(dict);       
                }
            }
        }
    }
}

更多详情请参考document

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2016-09-03
    • 1970-01-01
    • 2016-04-23
    • 2016-04-15
    • 1970-01-01
    • 2020-06-11
    • 2014-08-28
    • 2016-03-16
    相关资源
    最近更新 更多