[英]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.