为什么这个选择查询到Oracle(View)不起作用?

时间:2013-08-28 18:49:23

标签: c# sql oracle oracle11g odp.net

首先我测试了一些简单的案例:

cmd.Parameters.Add(new OracleParameter(":paramCode", OracleDbType.NVarchar2)).Value = userCode;
cmd.CommandText = "SELECT * FROM VIEWUSERDATA WHERE  Codigo = :paramCode";
cmd.CommandType = System.Data.CommandType.Text;
OracleDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
    //Works, retrieve data
}

另:

cmd.Parameters.Add(new OracleParameter(":paramRole", OracleDbType.NVarchar2)).Value = userRole;
cmd.CommandText = "SELECT * FROM VIEWUSERDATA WHERE  Role = :paramRole";
...
while (reader.Read())
{
    //Also works
}

但加入时,不起作用。

cmd.Parameters.Add(new OracleParameter(":paramCode", OracleDbType.NVarchar2)).Value = userCode;
cmd.Parameters.Add(new OracleParameter(":paramRole", OracleDbType.NVarchar2)).Value = userRole;
cmd.CommandText = "SELECT * FROM VIEWUSERDATA WHERE Role = :paramRole AND Code = :paramCode";
...
while (reader.Read())//don't retrieve anything
{
}

数据存在,如果我在外部查询编辑器(窗口)中执行查询工作正常。

感谢。

1 个答案:

答案 0 :(得分:4)

默认情况下,Oracle参数绑定是按位置,而不是按名称。在执行查询之前交换两个cmd.Parameters.Add调用或设置cmd.BindByName = true;