簡體   English   中英

在C#中將數據加載到DataTable中會出現“未知的SQL類型-0”錯誤

[英]Loading data to DataTable in C# gives “Unknown SQL type - 0” error

我已經成功使用以下代碼成功將ODBC連接中的數據加載到C# DataTable中一段時間​​了:

public static DataTable ExecuteSqlSelect(string sql, string connectionString)
        {
            var result = new DataTable();
            using (var connection = new OdbcConnection(connectionString))
            {
                connection.Open();

                var command = connection.CreateCommand();
                command.CommandText = sql;
                var dbReader = command.ExecuteReader();
                result.Load(dbReader);

                connection.Close();
            }

            return result;
        }

但是,我現在有一個MySql表,其中的列類型為JSON 當我嘗試使用該方法從該表加載數據時,出現以下錯誤:

Unknown SQL type - 0.

我認為這是因為C#的DataTable無法識別JSON類型。 這個對嗎? 更重要的是:是否有解決方案/解決方法?

編輯:我不是在試圖將JSON字符串轉換為數據表,正如評論者所建議的那樣。我正在嘗試將包含MySQL類型“ JSON”列的SQL表加載到數據表中。 我不需要JSON解析,如果我將原始JSON字符串放入DataTable中就可以了。

編輯2:MySql和ODBC連接器都是最新版本:8.0.11

感謝PaulF在評論中的建議,我得以解決此問題。 由於ODBC驅動程序不正確支持JSON,因此您必須直接在查詢中將列轉換為文本。 因此,如果在我之前:

SELECT col1, col2, jsonCol FROM table;

我將其替換為:

SELECT col1, col2, CAST(jsonCol as CHAR(256)) as jsonCol FROM table;

這會將列轉換為普通文本,然后將其正確加載到DataTable

我認為這更多是ODBC驅動程序不支持JSON數據類型的問題-我的建議來自此鏈接: https : //forums.mysql.com/read.php?37,650722,651027#msg - 651027-我在發行說明中找不到對JSON數據類型的任何引用。

您可以嘗試將列強制轉換為char / varchar作為解決方法。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM