1

我有以下代码:

Dim executedCmd As OleDb.OleDbCommand = m_dbMgr.GetCommand()
executedCmd.CommandText = "select * from [Parameters] where "
Dim SQLcondition As String = String.Empty
For i As Integer = 0 To ParameterName.Count - 1
 executedCmd.CommandText += "ParameterName = @parametername" + i.ToString() + " and ParameterValue @ParamaterCondition" + i.ToString() + " @ParameterValue" + i.ToString()
 executedCmd.Parameters.AddWithValue("@parametername" + i.ToString(), ParameterName(i))
 executedCmd.Parameters.AddWithValue("@ParameterValue" + i.ToString(), ParameterValue(i))
 executedCmd.Parameters.AddWithValue("@ParamaterCondition" + i.ToString(), Condition(i))
Next

ParameterName, ParameterValue, ParameterConditionall are the same length ArrayList,但代码无法正常工作。我已经验证了所有变量都有值。

当我运行代码时,它报告语法错误:“查询表达式中缺少操作”

问题在于它ParameterCondition的值如 ( '>', '<', '=',.... 一些逻辑 SQL 运算符)。

编辑:如何在参数中包含条件?

4

2 回答 2

1

在 where 之后添加1 = 1以简化构建逻辑表达式。请注意,所有条件都由AND逻辑运算符添加。您可以从列名称生成参数名称。

executedCmd.CommandText = "select * from [Parameters] where 1 = 1"

....
executedCmd.CommandText += " AND " + ParameterName(i) + " " + Condition(i) + " @" + ParameterName(i)
executedCmd.Parameters.AddWithValue("@" + ParameterName(i), ParameterValue(i))

ParameterCondition 必须都是二元运算符。

于 2013-02-01T07:04:19.313 回答
0

数据库引擎会在将参数替换为值之前检查 SQL 语句的语法。所以像 "WHERE @p1 @p2 @p3" 这样的东西不会被正确解析。用字符串表达式替换您的条件,例如

commandtext = parameterName + condition + " @p1"
于 2013-02-01T07:01:14.493 回答