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, и вы увидите, что произойдет. Кроме того, я согласен с "вы должны предоставить формат, потому что вы не можете полагаться на значение по умолчанию".

Другие вопросы по тегам