`
txf2004
  • 浏览: 6867677 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

ASP实现SQL语句日期格式的加减运算

阅读更多

需要按时间查询,可是查询出来的结果显示的不正确。举个例子来说,要查找出2007-10-12至2007-10-31之间在网站上注册的会员,选择好日期后,点击“查询”按钮,发现2007-10-31注册的会员的信息根本没有显示出来,试验了几次结果都是一样。调试程序发现,原来是在SQL语句这里出现了问题。

  SQL语句如下:SELECT * FROM userinfo WHERE regtime >= '2007-10-12' AND regtime <= '2007-10-31'。初看上去这条SQL语句没有错误,可是对照数据库中相应字段保存的值以后,发现保存的值并不是简单的日期形式,而是日期+时间的形式,即:yyyy-MM-dd HH:mm:ss,这时SQL语句在判断regtime和'2007-10-31'的大小时,会认为'2007-10-31'写的不完整,所以不会认为这两个值是相等的。这可怎么办呢?

  不用着急,ASP为我们提供了日期加减的函数,来帮我们解决这一问题。

  1.日期相加

  DateAdd 函数

  返回已添加指定时间间隔的日期。

  DateAdd(interval, number, date)

  DateAdd 函数的语法有以下参数

  (1)interval 必选项。字符串表达式,表示要添加的时间间隔。有关数值,请参阅“设置”部分。

  (2)number 必选项。数值表达式,表示要添加的时间间隔的个数。数值表达式可以是正数(得到未来的日期)或负数(得到过去的日期)。

  (3)date  必选项。Variant 或要添加 interval 的表示日期的文字。

  说明

  可用 DateAdd 函数从日期中添加或减去指定时间间隔。例如可以使用 DateAdd 从当天算起 30 天以后的日期或从现在算起 45 分钟以后的时间。要向 date 添加以“日”为单位的时间间隔,可以使用“一年的日数”(“y”)、“日”(“d”)或“一周的日数”(“w”)。

  DateAdd 函数不会返回无效日期。如下示例将 95 年 1 月 31 日加上一个月:

  NewDate = DateAdd("m", 1, "31-Jan-95")

  在这个示例中,DateAdd 返回 95 年 2 月 28 日,而不是 95 年 2 月 31 日。如果 date 为 96 年 1 月 31 日,则返回 96 年 2 月 29 日,这是因为 1996 是闰年。

  如果计算的日期是在公元 100 年之前,则会产生错误。

  如果 number 不是 Long 型值,则在计算前四舍五入为最接近的整数。

  2.日期相减

  DateDiff 函数

  返回两个日期之间的时间间隔。

  DateDiff(interval, date1, date2 [,firstdayofweek[, firstweekofyear]])

  DateDiff 函数的语法有以下参数:

  (1)interval 必选项。字符串表达式,表示用于计算 date1 和 date2 之间的时间间隔。有关数值,请参阅“设置”部分。

  (2)date1, date2 必选项。日期表达式。用于计算的两个日期。

  (3)Firstdayofweek 可选项。指定星期中第一天的常数。如果没有指定,则默认为星期日。有关数值,请参阅“设置”部分。

  (4)Firstweekofyear 可选项。指定一年中第一周的常数。如果没有指定,则默认为 1 月 1 日所在的星期。有关数值,请参阅“设置”部分。

  说明

  DateDiff 函数用于判断在两个日期之间存在的指定时间间隔的数目。例如可以使用 DateDiff 计算两个日期相差的天数,或者当天到当年最后一天之间的星期数。

  要计算 date1 和 date2 相差的天数,可以使用“一年的日数”(“y”)或“日”(“d”)。当 interval 为“一周的日数”(“w”)时,DateDiff 返回两个日期之间的星期数。如果 date1 是星期一,则 DateDiff 计算到 date2 之前星期一的数目。此结果包含 date2 而不包含 date1。如果 interval 是“周”(“ww”),则 DateDiff 函数返回日历表中两个日期之间的星期数。函数计算 date1 和 date2 之间星期日的数目。如果 date2 是星期日,DateDiff 将计算 date2,但即使 date1 是星期日,也不会计算 date1。

  如果 date1 晚于 date2,则 DateDiff 函数返回负数。

  firstdayofweek 参数会对使用“w”和“ww”间隔符号的计算产生影响。

  如果 date1 或 date2 是日期文字,则指定的年度会成为日期的固定部分。但是如果 date1 或 date2 被包括在引号 (" ") 中并且省略年份,则在代码中每次计算 date1 或 date2 表达式时,将插入当前年份。这样就可以编写适用于不同年份的程序代码。

  在 interval 为“年”(“yyyy”)时,比较 12 月 31 日和来年的 1 月 1 日,虽然实际上只相差一天,DateDiff 返回 1 表示相差一个年份

分享到:
评论

相关推荐

    ASP 日期的加减运算实现代码

    调试程序发现,原来是在SQL语句这里出现了问题。...初看上去这条SQL语句没有错误,可是对照数据库中相应字段保存的值以后,发现保存的值并不是简单的日期形式,而是日期+时间的形式,即:yyyy-MM-dd HH:mm:s

    经典全面的SQL语句大全

    根据SQL语句执行后是否返回记录集,该方法的使用格式分为以下两种:  1.执行SQL查询语句时,将返回查询得到的记录集。用法为:  Set 对象变量名=连接对象.Execute("SQL 查询语言")  Execute方法调用后,会自动...

    网页版 ASP管理员密码探索工具

    简介:利用ASP中SQL语句的漏洞,自动猜测运算,并获取网站的管理员帐号和密码的一个小工具。 asppwd.asp ----ASP网站管理员帐号密码探测 asppwdAT.txt ----存放管理员帐号密码的表名字典 asppwdAU.txt ----存放管理...

    十天学会ASP.net--我认为ASP.NET比ASP难很多,希望大家做好准备

    虽然说学习ASP.NET不需要任何ASP基础,但是我觉得如果大家ASP不会,还是先看一下【十天学会ASP教程】,大家所需要了解的不是ASP的程序怎么写,而是怎么构建服务器,怎么使用HTML表单,同时对SQL语句有一个基础和理解...

    asp.net知识库

    运算表达式类的原理及其实现 #实现的18位身份证格式验证算法 身份证15To18 的算法(C#) 一组 正则表达式 静态构造函数 忽略大小写Replace效率瓶颈IndexOf 随机排列算法 理解C#中的委托[翻译] 利用委托机制处理.NET中...

    SQL语法大全

    rs.open SQL语句,conn,3,2 3. SQL常用命令使用方法: (1) 数据记录筛选: sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]" sql="select * from 数据表 where 字段名 like \'%字段值%\'...

    asp在线考试系统(asp+access实现)

    但是所有SQL语句都必须由数据库服务器独立地执行。这就意味着客户端应用必须把每条查询发送到数据库服务器,等待它处理这个查询,接收结果,做一些运算,然后给服务器发送另外一条查询。所有这些东西都会产生进程间...

    存储过程教程

    无论是存储过程还是触发器,都是SQL 语句和流程控制语句的集合。就本质而言,触发器也是一种存储过程。存储过程在运算时生成执行方式,所以,以后对其再运行时其执行速度很快。SQL Server 2000 不仅提供了用户自定义...

    ASP设计在线考试系统OnlineTest

    但是所有SQL语句都必须由数据库服务器独立地执行。这就意味着客户端应用必须把每条查询发送到数据库服务器,等待它处理这个查询,接收结果,做一些运算,然后给服务器发送另外一条查询。所有这些东西都会产生进程间...

    C#开发经验技巧宝典

    0872 格式化日期显示格式 515 0873 如何正确理解SQL中的NULL值 516 0874 如何使用IsNull()函数来处理空值 516 0875 如何使用Nullif()函数来处理空值 516 0876 查询空值(NULL)的技巧 517 0877 利用...

    VBScript介绍手册

    1.1 Internet的基本情况 1.1.1 Internet的起源与商业化发展 1.1.2 Internet的服务内容 1.1.3 TCP/IP协议 1.1.4 Internet中的主机管理与域名系统 1.1.5 Internet的工作原理 ...14.2.3 获取SQL语句的执行结果 小 结

    C#编程经验技巧宝典

    27 &lt;br&gt;0056 强行改变运算符的运算顺序 27 &lt;br&gt;第3章 程序算法 29 &lt;br&gt;3.1 数据结构 30 &lt;br&gt;0057 如何实现单向链表 30 &lt;br&gt;0058 如何实现双向链表 35 &lt;br&gt;0059 如何实现堆栈 41 ...

    php的快速入门小高手

    至于表单设计什么的,我这里也不想多说了,在《十天学会ASP》中已经有介绍。 下面简单介绍一下PHP的语法。 1、嵌入方法: 类似ASP的,PHP可以是或者是,结束符号是?&gt;,当然您也可以自己指定。 2、引用文件: ...

    ASP.NET编程之道.part1.rar

    谬误01 所有的异常都要使用try…catch语句捕获 谬误02 Web控件的Enabled功能等价于HTML控件的 disabled属性 谬误03 将Session设置为空就是删除该会话状态 谬误04 RegisterStartupScript方法不能向页面输出文本 谬误...

    一句话轻松搞定asp.net分页

    rows 是客户端传过来的行数,page是页码,传参就需要就两个参数就行,sql语句中_row 和_page 自己声明的局部变量,值还是相应的row 和page ,为了运算而已。 用数据库类获得它的DataTable,转换为json格式通过一般...

    hdongix c++

    MSSQL如果你是使用MSSQL数据库的话,必会用到SQL的日期函数,这里整理最详细的用法: 1.当前系统日期、时间 select getdate() 2. dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值 例如:向日期...

    Visual C#2010 从入门到精通(Visual.C#.2010.Step.By.Step).完整去密码锁定版 I部分

    书中沿袭深受读者欢迎的step by step风格,通过丰富的练习引导读者逐步构建windows应用程序,访问sql server数据库,开发asp.net web应用程序,创建并使用web服务等。  全书共29章,结构清晰,叙述清楚。所有练习均...

    第5章-数据库系统.docx

    A 身份证号码 B 姓名 C 出生日期 D 身份证号码+姓名 13:关系代数运算的对象是 __A____。 A 关系 B 值 C 域 D 列 14:若1={1, 2, 3}, 2={1, 2, 3},则1×2集合中共有元组___C___个。 A 6 B 8 C 9 D 12 15:数据库管理...

    工作易人才招聘系统V2.5

    工作易人才招聘系统作为工作易人才招聘系统V2.5是基于Win32平台,采用微软.Net2.0(Aspx)+MSSQL 2000(2005)为开发、运行环境,语言天生运算速度是ASP的2-3倍,安全和稳定性更是asp所无法比拟和超越的。其安装简单方便...

    工作易人才招聘系统 v190514.rar

    数据库管理、备份数据库、恢复数据库、执行SQL语句; 视频管理、添加视频、修改、删除视频及信息、推荐、置顶视频; 在线支付设置、文章采集管理、调查投票管理、会员充值卡管理、邮件群发管理、职位订阅管理; ...

Global site tag (gtag.js) - Google Analytics