У меня есть программа, которая запускает операторы SQL через MySQL ODBC Connector. Когда я использую заполнитель для запроса SELECT для таблицы с типом столбца геометрии, возникает исключение.
Это код
static void Main(string[] args)
{
try
{
using (OdbcConnection connection = new OdbcConnection(ConnectionString))
{
connection.Open();
OdbcCommand command = new OdbcCommand("DROP TABLE IF EXISTS TestT", connection);
command.ExecuteNonQuery();
command.CommandText = "CREATE TABLE TestT(ID INT, NAME VARCHAR(20), DeliveryLocation geometry DEFAULT NULL)";
command.ExecuteNonQuery();
command.CommandText = "INSERT INTO TestT(ID, NAME) VALUES(1, 'DT'),(2, 'teamDT')";
command.ExecuteNonQuery();
command.CommandText = "SELECT * FROM TestT where id = ?";
var parameter = new OdbcParameter("Parameter1", OdbcType.Int);
parameter.Direction = ParameterDirection.Input;
parameter.Value = 1;
command.Parameters.Add(parameter);
var adapter = new OdbcDataAdapter
{
SelectCommand = command
};
var dataSet = new DataSet();
adapter.Fill(dataSet);
var table = dataSet.Tables[0];
Console.WriteLine($"Number of rows returned: {table.Rows.Count}");
}
}
catch (OdbcException exception)
{
for (int i = 0; i < exception.Errors.Count; i++)
{
Console.WriteLine("ERROR #" + i + "\n" + "Message: " +
exception.Errors[i].Message + "\n" +
"Native: " +
exception.Errors[i].NativeError.ToString() + "\n" +
"Source: " +
exception.Errors[i].Source + "\n" +
"SQL: " +
exception.Errors[i].SQLState + "\n");
}
}
}
Запустив его, я получаю следующий вывод
ERROR #0
Message: [MySQL][ODBC 5.3(a) Driver][mysqld-5.7.23-log]
Native: 517
Source: myodbc5a.dll
SQL: HY000
Если я изменяю тип DeliveryLocation на int или удаляю столбец из таблицы, или меняю инструкцию SELECT на
SELECT * FROM TestT where id = 1
Я получаю следующий ответ
Number of rows returned: 1
Как можно предотвратить возникновение ошибки, не удаляя или не изменяя тип столбца, и сохраняя использование заполнителя (?) В операторе SELECT?
Я использую драйвер MySQL ODBC 5.3 ANSI и MySQL 5.7.23