【发布时间】:2014-01-09 16:16:45
【问题描述】:
我有一个查询,我需要使用 Oracle 检查两个日期之间的日期。每当我运行代码时,我都会收到 ORA-01843: not a valid month 错误。但是,每当我从 sql 中删除两个参数中的任何一个时,它都可以正常工作,但是尝试使用两个日期参数会引发错误。我错过了什么?
StringBuilder sql = new StringBuilder();
DateTime yearBegin = new DateTime(Convert.ToInt32(taxYear) + 1, 1, 1);
DateTime yearEnd = new DateTime(Convert.ToInt32(taxYear) + 1, 12, 31);
sql.Append(
"SELECT * FROM TABLE WHERE FIELD = '1099' AND CREATED_DT >= TO_DATE(:createdYearBegin, 'MM/DD/YYYY') AND CREATED_DT <= TO_DATE(:createdYearEnd, 'MM/DD/YYYY') AND SSN = :ssn");
try
{
using (OracleConnection cn = new OracleConnection(ConfigurationManager.AppSettings["cubsConnection"]))
using (OracleCommand cmd = new OracleCommand(sql.ToString(), cn))
{
cmd.Parameters.Add("ssn", ssn);
cmd.Parameters.Add("createdYearBegin", yearBegin.ToShortDateString());
cmd.Parameters.Add("createdYearEnd", yearEnd.ToShortDateString());
cn.Open();
OracleDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
ret = dr.HasRows;
}
}
【问题讨论】:
-
在调试器中查看时,日期是正确的,如果 ToShortDateString() 的结果有问题,那么无论有一个或两个日期参数,它都会有同样的问题,但是因为如果我删除一个或另一个日期参数,并仅使用其中一个参数运行它,它可以正常工作。
-
那么你能看到两个日期生成的sql是什么吗?此处示例:stackoverflow.com/questions/265192/…
-
SQL 符合预期(尽管我必须在日期周围添加单引号:SELECT * FROM TABLE WHERE FIELD = '1099' AND CREATED_DT >= TO_DATE('1/1/2014', 'MM/DD/YYYY') AND CREATED_DT
标签: sql oracle datetime oraclecommand