我有这个查询:
SELECT * FROM records WHERE serial LIKE '%19-111117-11%';
序列列是varchar字段。这里没有日期/时间。也许.Net或MySQL认为'19 -111117-11'是日期?
我收到此错误:
MySql.Data.Types.MySqlConversionException:'无法将MySQL日期/时间值转换为System.DateTime'
奇怪的是,该查询在MySql查询浏览器中工作正常,但是在我的C#应用程序中运行时会抛出该异常。
我尝试过:
SELECT * FROM records WHERE CAST(serial as char) LIKE '%19-111117-11%';
就它的地狱而言,我将“ 19-111117-11”分为两个部分:
(kinda伪代码,因为之后我尝试了更多事情)
string p1 = serial.substring(0, serial.length/2)
string p2 = serial.substring(serial.length)
string query = "SELECT * FROM records WHERE SUBSTRING(serial,0,LENGTH(serial)/2) = " + p1 + "' AND SUBSTRING(serial,LENGTH(serial)/2,LENGTH(serial)/2) = '" + p2 + "';";
请帮助!如此烦人的问题。我不确定为什么会得到转换为日期/时间的异常。我根本不使用日期...
编辑:
SELECT * FROM records WHERE `serial` LIKE '%19-111117-11%';
此外,它不起作用。我认为它与C#代码无关,因为它只是一个查询,而且是MySQL异常,但这是使用的代码:
string serial = "19-111117-11";
DataTable tracking_info = MySqlGetDataTable("SELECT * FROM records WHERE `serial` LIKE '%" + serial + "%';");
调用此函数:
public static DataTable MySqlGetDataTable(string query, string connString = "default")
{
var data = new DataTable();
using (var conn = new MySqlConnection(connString == "default" ? Program.CidDataConnectionString : connString))
{
var adapter = new MySqlDataAdapter(query, conn);
adapter.Fill(data);
}
return data;
}
编辑2:
使用序列号:19-111115-11,19-111116-11,19-111118-11都可以使用...只是19-111117-11不能使用。似乎与以下内容有关:
19-11111 7 -11 <-该数字
答案 0 :(得分:2)
在应用配置文件中设置“零日期时间=真”
<add name="CONNECTIONSTRINGNAME" connectionString="server's HOSTNAMEorIP(i.e Localhost or IP address);user id=USER_ID;Pwd=PASSWORD;persistsecurityinfo=True;database=DATABASENAME;Convert Zero Datetime=True" providerName="MySql.Data.MySqlClient"/>
答案 1 :(得分:0)
SELECT * FROM records WHERE `serial` LIKE '%19-111117-11%';
不起作用,但是:
SELECT col1, col2, col3... FROM records WHERE `serial` LIKE '%19-111117-11%';
工作。