C# AND ACCESS - 标准表达式中的数据类型不匹配
Posted
技术标签:
【中文标题】C# AND ACCESS - 标准表达式中的数据类型不匹配【英文标题】:C# AND ACCESS - Data type mismatch in criteria expression 【发布时间】:2013-05-20 08:40:48 【问题描述】:我创建了一个代码,用于更新/编辑连接到 MS Access 的 C# 程序的计算机/电子产品的详细信息。以下是代码:
OleDbCommand cmd = new OleDbCommand("UPDATE Available SET ProductType = '" + newAvailable.ProductType + "', Brand = '"+ newAvailable.Brand + "', Model = '" + newAvailable.Model + "', SerialNo = '" + newAvailable.SerialNo + "', Remarks = '" + newAvailable.Remarks + "', RAM = '" + newAvailable.RAM + "', HDD = '" + newAvailable.HDD + "', ODD = '" + newAvailable.ODD + "', VideoCard = '" + newAvailable.VideoCard + "', PS = '" + newAvailable.PS + "' WHERE AvailableID = '"+oldAvailable.AvailableID+"'", cnn);
cmd.CommandType = CommandType.Text;
cnn.Open();
cmd.ExecuteNonQuery();
cnn.Close();
AvailableID 接受 Int32 值,其余变量为字符串。该程序是可执行的,但 C# 检测到错误。
条件表达式中的数据类型不匹配。
我该怎么办?
【问题讨论】:
availableID 是数字字段? 是的。 availableID 是数字字段。访问和c# 如果可用 ID 是数字字段,那么为什么它在单引号中传递..尝试删除引号,例如 Where AvailableID="+oldAvailable.AvailableID+" 谢谢,凯尔。代码现在可以运行,记录终于可以更新了。 【参考方案1】:我怀疑您没有传递正确的参数之一,可能是AvailableID
,而是尝试以这种方式添加参数:
var cmd = new OleDbCommand
Connection = cnn,
CommandType = CommandType.Text,
CommandText = "UPDATE Available SET ProductType = ?, Brand = ?, Model = ?, SerialNo = ?, Remarks = ?, RAM = ?, ODD = ?, VideoCard = ?, PS = ? WHERE AvailableID = ?"
;
cmd.Parameters.Add(new OleDbParameter Value = newAvailable.ProductType);
cmd.Parameters.Add(new OleDbParameter Value = newAvailable.Brand);
// add the other parameters ...
附带说明一下,通过连接字符串来生成查询并不是一个好主意,您应该始终使用参数。
【讨论】:
参数是否应该按照列的队列排列?顺便感谢您的帮助,Dimitar。 它们应该按照您在查询中使用它们的顺序(产品然后品牌然后型号......等),如果是 SqlDbCommand,您可以命名它们,但是对于 OleDbCommand,它们需要在正确的顺序。非常欢迎你:)【参考方案2】:删除('')那些具有整数值的人
【讨论】:
【参考方案3】:试试这个
OleDbCommand cmd = new OleDbCommand("UPDATE Available SET ProductType = '" + newAvailable.ProductType + "', Brand = '"+ newAvailable.Brand + "', Model = '" + newAvailable.Model + "', SerialNo = '" + newAvailable.SerialNo + "', Remarks = '" + newAvailable.Remarks + "', RAM = '" + newAvailable.RAM + "', HDD = '" + newAvailable.HDD + "', ODD = '" + newAvailable.ODD + "', VideoCard = '" + newAvailable.VideoCard + "', PS = '" + newAvailable.PS + "' WHERE AvailableID = "+oldAvailable.AvailableID, cnn);
cmd.CommandType = CommandType.Text;
cnn.Open();
cmd.ExecuteNonQuery();
cnn.Close();
【讨论】:
【参考方案4】:简单的就是在这个上面放一个调试点并检查查询。复制它并直接在访问中运行它并使用数据进行更改。你会发现你输入的参数值是错误的。
【讨论】:
【参考方案5】:我会使用这样的东西来实现你想要做的事情。此代码适用于我的 MS Access 2013
//setting up connection.
OleDbConnection conn = new OledbConnection("connectionstring goes here");
//set the command string query
string cmdStr = "UPDATE Available SET ProductType = ?, Brand = ?, Model = ?, SerialNo = ?, Remarks = ?, RAM = ?, ODD = ?, VideoCard = ?, PS = ? WHERE AvailableID = ?";
//create the command
OleDbCommand cmd = new OleDbCommand(cmdStr,conn);
//add parameters
cmd.Parameters.AddWithValue("@p1",newAvailable.Brand);
cmd.Parameters.AddWithValue("@p2",newAvailable.Brand);
cmd.Parameters.AddWithValue("@p3",newAvailable.SerialNo);
// add all your parameters in the correct order here below .
【讨论】:
以上是关于C# AND ACCESS - 标准表达式中的数据类型不匹配的主要内容,如果未能解决你的问题,请参考以下文章
C# Access OleDb 条件表达式中的数据类型不匹配
使用 Decimal 参数的数据类型不匹配 - OleDb、C#、Access
尝试插入 Access 数据库时,条件表达式中的数据类型不匹配错误