Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 查询  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702052
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

字段默认值设定为NOW为什么查不到明明存在的2005-11-30的值?

作者:cg1  摘自:access911.net  :cg1  更新日期:2005-12-14  浏览人次:

 

问题:

select thread_title,threadID from JB_thread where postuserid=428 and (posttime BETWEEN #2005-11-01# and #2005-11-30#) 
posttime 是ACCESS时间类型字段 包含2005-11-30的数据
但查询结果并没有2005-11-30的数据?
为什么?如何解决?
posttime 用的日期类型 设默认值为NOW()
数据库中有2005-11-1 到2005-12-12的所有记录(每天都有记录)
但查2005-11-1 到2005-11-30 的记录,惟独少2005-11-30 这一天的

 

回答:

如果你的 posttime 的默认值是 NOW ,那么数据库中 posttime  字段存储的值类似

2005-11-30 12:00:25

如果你用 SQL

select thread_title,threadID from JB_thread where postuserid=428 and (posttime BETWEEN #2005-11-01# and #2005-11-30#) 

来搜索值,那么 JET DB 会自动给你加上

select thread_title,threadID from JB_thread where postuserid=428 and (posttime BETWEEN #2005-11-01 00:00:00# and #2005-11-30 00:00:00#) 


00:00:00 你想不要都不行。解决方法是

直接写 SQL 代码如下
select thread_title,threadID from JB_thread where postuserid=428 and (posttime BETWEEN #2005-11-01 00:00:00# and #2005-11-30 23:59:59#) 

或者

select thread_title,threadID from JB_thread where postuserid=428 and format(posttime,"yyyy-mm-dd")>='2005-11-01' and  format(posttime,"yyyy-mm-dd")<='2005-11-30'

注意, FORMAT 函数需要 ACCESS DRIVER 支持,如果你是 vb+JETDB 等方法开发,可能不支持。

 

问题:

把日期字段设置成字符型的了,按日期字段查询时老是不正确,比如2006-3-7至2006-4-7的数据输入这两个值查的数据就不完全,把字段改成短日期型的,又老是类型不批配,怎么回事呀?

 

回答:

ACCESS 中不存在短日期类型,只有短日期格式

关于此主题请参考以下文章(不要只看标题,请认真仔细地察看上述文章以及相关的评论):
    如何清楚认识什么是数据,以及什么是显示格式?《表》
    http://access911.net/index.asp?u1=a&u2=72FAB11E10DCEFF3
关于此主题请参考以下文章(不要只看标题,请认真仔细地察看上述文章以及相关的评论):
    如何清楚认识什么是数据,以及什么是显示格式?(二)
    http://access911.net/index.asp?u1=a&u2=72FAB11E17DCEBF3

可能是数据库内部存储为
2006-4-7 12:55:12
但是你用 
select * from table where datefield between #2006-3-1# and #2006-4-7#
就无法找全信息,因为查询时系统会自动转换为
select * from table where datefield between #2006-3-1 00:00:00# and #2006-4-7 00:00:00#

用以下语句就可以了
select * from table where datefield between #2006-3-1 00:00:00# and #2006-4-7 12:59:59#

关于此主题请参考以下文章(不要只看标题,请认真仔细地察看上述文章以及相关的评论):
    字段默认值设定为NOW为什么查不到明明存在的2005-11-30的值?《查询》
    http://access911.net/index.asp?u1=a&u2=72FAB11E16DCECF3

 


本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
     如何填写“默认值”属性?默认值属性能否使用表达式?
     如何设定表的某字段默认值?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利