2-й параметр даты бросает ORA-01843: недопустимая ошибка месяца
У меня есть запрос, где мне нужно проверить дату между двумя датами, используя 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;
}
}
3 ответа
Я думаю, что у вас есть проблемы с порядком вашего параметра.
Если вы не связываете параметры по имени, они привязываются по положению (означает порядок, в котором вы добавляете параметры, берется).
Просто попробуйте добавить:
cmd.BindByName = true;
Вы ожидаете дату в формате MM/DD/YYYY
, но это не гарантирует, что ToShortDateString()
возвращает его в этом формате. Требуется спецификация формата. Но я даже не знаю, какой язык программирования вы используете для оказания дальнейшей помощи...
Распечатайте результаты ToShortDateString, и вы увидите, что произойдет. Кроме того, я согласен с "вы должны предоставить формат, потому что вы не можете полагаться на значение по умолчанию".