首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Python / pyodbc -用于筛选日期的哪个语句?

Python / pyodbc -用于筛选日期的哪个语句?
EN

Stack Overflow用户
提问于 2015-11-18 16:06:10
回答 2查看 3.1K关注 0票数 0

我使用pydoc从sql数据库中获取数据。

我想使用WHERE语句过滤日期。我有:

代码语言:javascript
运行
复制
cursor.execute("SELECT isnull(SOP30200.SOPNUMBE,''), isnull(SOP30200.docdate,'') from SOP30200 where SOP30200.docdate > datetime.datetime(2015,1,1,0,0)")

我得到了一个错误:

代码语言:javascript
运行
复制
ProgrammingError: ('42000', '[42000] [Microsoft][ODBC SQL Server Driver][SQL Server]Cannot find either column "datetime" or the user-defined function or aggregate "datetime.datetime", or the name is ambiguous. (4121) (SQLExecDirectW)') 

没有WHERE语句,我成功地获得了数据。我确实检查了取出的"docdate“字段的类型,它是datetime.datetime。

编辑:还应该指出提取的日期是在表单datetime.datetime(2013, 5, 8, 0, 0)中。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-11-18 16:22:54

您需要使用参数注入/内插日期。server正试图按原样运行SQL语句,并期望数据库中存在一个datetime.datetime(..)函数。

代码语言:javascript
运行
复制
cursor.execute("SELECT isnull(SOP30200.SOPNUMBE,''), isnull(SOP30200.docdate,'') from SOP30200 where SOP30200.docdate > ?", datetime.datetime(2015,1,1,0,0))

参见http://mkleehammer.github.io/pyodbc/ -参数一节

票数 4
EN

Stack Overflow用户

发布于 2015-11-18 16:23:57

"datetime.datetime“不是函数,是Python库的类。

可能是:

代码语言:javascript
运行
复制
cursor.execute("SELECT isnull(SOP30200.SOPNUMBE,''), isnull(SOP30200.docdate,'') from SOP30200 where SOP30200.docdate > ?", datetime.datetime(2015,1,1,0,0))
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33784847

复制
相关文章

相似问题

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