【问题标题】:2nd Date Parameter Throws ORA-01843: not a valid month error第二个日期参数抛出 ORA-01843: not a valid month 错误
【发布时间】: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


【解决方案1】:

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

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

尝试添加:

cmd.BindByName = true;

【讨论】:

  • 日期是正确的,如果 ToShortDateString() 的结果有问题,那么无论有一个还是两个日期参数都会有同样的问题,但是如果我删除一个,或其他日期参数,并仅使用其中一个参数运行它就可以了。
  • @UnHolyRam 我发现了别的东西,你能试试吗?
  • 我们有一个赢家。谢谢
【解决方案2】:

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

【讨论】:

    【解决方案3】:

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

    【讨论】:

    • C# 中的 DateTime 使用 0 到 11 吗?真的吗 ?这是哪里来的?
    • 对我来说看起来像 Java,并且 OP 没有提供语言标签。删除了我回答的那部分。
    猜你喜欢
    • 1970-01-01
    • 2017-04-01
    • 1970-01-01
    • 1970-01-01
    • 2013-03-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-07-24
    相关资源
    最近更新 更多