我有一个抛出一个代码行
Oracle 异常 - ORA-00911:无效字符
尝试以下 C# 代码时:
double tempDateTimeObj = Convert.ToDouble(someClass.GetTime(tempObjID, objStartTime, todayTime).Rows[0][0]);
GetTime 是一个进行 SQL 调用的函数,该函数接受您在上面看到的变量,并且 SQL 调用输出一个 Oracle 数字类型,然后 GetTime C# 函数DataTableCollection Tables
每次返回一个行的对象。
public static DataTable GetTime(string tempObjID, DateTime objStartTime, DateTime todayTime)
{
string sql = "select some_pkg.get_time('" + tempObjID + "', to_date('" + objStartTime + "', 'mm/dd/yyyy hh:mi:ss am'), to_date('" + todayTime + "', 'mm/dd/yyyy hh:mi:ss am')) from dual;";
return <connection object>.getDS(sql).Tables[0];
}
如果我调试,获取具有变量值的 sql 字符串,并将其放入 Oracle SQL Developer 中,它工作得很好,并在 SQL Dev 控制台中返回一个数字。但是,当我调试并遇到该行时,C# 代码会引发 00911 异常。由于字符串 sql 已经在 Oracle SQL Dev 中测试过,因此语法应该是有效的。给定有效的语法,为什么 VS2010 会抛出这个错误/异常?
编辑: 这是在 C# 中构建并发送到数据库的示例字符串:
select some_pkg.get_time('23569245', to_date('11/8/2012 1:21:06 PM', 'mm/dd/yyyy hh:mi:ss am'), to_date('12/31/2012 12:52:18 AM', 'mm/dd/yyyy hh:mi:ss am')) from dual
尽管都在 Oracle SQL Dev 中工作,但已尝试在 C# 字符串中使用分号和没有分号并导致相同的 Oracle 异常