0

我有一个查询,我需要使用 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;
            }
        }
4

3 回答 3

1

认为您的参数顺序有问题。

如果您不按名称绑定参数,则它们按位置绑定(意味着您添加参数的顺序)。

只需尝试添加:

cmd.BindByName = true;
于 2014-01-09T16:25:06.713 回答
0

您期望日期格式为MM/DD/YYYY,但不能保证ToShortDateString()以这种格式返回它。需要格式规范。但是好吧,我什至不知道您使用什么编程语言来提供进一步的帮助......

于 2014-01-09T16:25:46.297 回答
0

打印出 ToShortDateString 的结果,你会看到会发生什么。另外,我同意“您应该提供一种格式,因为您不能依赖默认值”。

于 2014-01-09T16:29:19.463 回答