SqlServer更新错误:OleDbException 必须声明标量变量
SqlServer更新错误:OleDbException 必须声明标量变量。
昨天遇到的问题:数据库访问更新用的是OleDbCommand。
传递的语句:"select * from xml_web where id=@id"
系统一直报错:必须声明标量变量@id
确认所有没有问题,网上搜索了一下:
原来要用"select * from xml_web where id=?"
Comm.Parameters.Add(new OleDbParameter("@P1", OleDbType.VarChar)).Value = "123";
真是恶心,MSDN的说法:
使用参数化 DbCommand 的一个缺点是需要参数的代码将仅适用于支持相同语法的提供程序。OLEDB、SqlClient 和 Oracle 提供程序全部使用不同的语法。例如,用于命名和指定参数的 SQL 语法使用 @ 符号,OLEDB 参数语法需要使用问号 (?) 作为参数占位符,而 Oracle 提供程序使用冒号 (:)。
如果希望创建的解决方案不需要创建自定义代码块来适应提供程序特定的 SQL 语法,即可适用于不同的提供程序,您将需要使用基本的 ANSI SQL 语法,并避免使用参数以及提供程序特定的语言功能。可以创建一个 DbCommand 对象,并使用字符串串联动态构造将适用于多个提供程序的有效 SQL 语句。您还将需要解决的问题是:不同的提供程序支持的日期/时间数据类型的数据类型分隔符也不同。以下代码段说明如何串联从 SELECT 语句的变量检索到的 WHERE 子句的值。
tags: