我有一个查询,我需要使用Oracle检查两个日期之间的日期。每当我运行代码时,我得到一个ORA-01843:不是有效月份错误。但是,每当我从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;
}
}
答案 0 :(得分:1)
认为你的参数订单有问题。
如果不按名称绑定参数,则它们按位置绑定(表示添加参数的顺序)。
试着添加:
cmd.BindByName = true;
答案 1 :(得分:0)
您希望日期格式为MM/DD/YYYY
,但不保证ToShortDateString()
以此格式返回日期。需要格式规范。但是,我甚至不知道你用来提供进一步帮助的编程语言是什么......
答案 2 :(得分:0)
打印出ToShortDateString的结果,你会看到会发生什么。此外,我同意“你应该提供一种格式,因为你不能依赖默认值。”