首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >第二个日期参数抛出ORA-01843:无效的月份错误

第二个日期参数抛出ORA-01843:无效的月份错误
EN

Stack Overflow用户
提问于 2014-01-09 16:16:45
回答 3查看 922关注 0票数 0

我有一个查询,需要使用Oracle检查两个日期之间的日期。每当我运行代码时,我都会得到一个ORA-01843:不是一个有效的月份错误。但是,每当我从sql中删除这两个参数中的任何一个时,它都可以正常工作,但尝试使用两个日期参数会引发错误。我遗漏了什么?

代码语言:javascript
运行
复制
        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;
            }
        }
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-01-09 16:25:06

你觉得你的参数的顺序有问题。

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

只需尝试添加:

代码语言:javascript
运行
复制
cmd.BindByName = true;
票数 1
EN

Stack Overflow用户

发布于 2014-01-09 16:25:46

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

票数 0
EN

Stack Overflow用户

发布于 2014-01-09 16:29:19

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21025523

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档