Sql 查询当天、本周、本月记录

    1. Sql 查询当天、本周、本月记录  
    2. --查询当天:      
    3. select * from info where DateDiff(dd,datetime,getdate())=0      
    4.      
    5. --查询24小时内的:      
    6. select * from info where DateDiff(hh,datetime,getDate())<=24      
    7.      
    8. --info为表名,datetime为数据库中的字段值     
    9. -- 查询当天: select * from table where DateDiff(dd,datetime,getdate())=0 --查询24 小时内 的: select * from table where DateDiff(hh,datetime,getDate())<=24 --table 为 表名,datetime为数据库中的字段值  
    10.   
    11. DATEDIFF 函数:  
    12. 语法:  
    13.   
    14. DATEDIFF ( datepart , startdate , enddate )  
    15. 备注:  
    16. enddate 减去 startdate。如果 startdate 晚于 enddate,则返回负值。  
    17. 如果结果超出整数值范围,则 DATEDIFF 将产生错误。对于毫秒,最大数是 24 天 20 小时 31 分钟零 23.647 秒。对于秒,最大数是 68 年。  
    18. 跨 分钟、秒和毫秒等边界计算的方法使得 DATEDIFF 指定的结果在所有数据类型中均一致。结果是带正负号的整数值,它等于跨第一个和第二个日期间 的 datepart 边界数。例如,在 1 月 4 日(星期日)和 1 月 11 日(星期日)之间的星期数是 1。  
    19. --本月记录     
    20. SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=0      
    21.      
    22. --本周记录      
    23. SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=0      
    24.      
    25. --包括本年这些查询方式是一样的      
    26.       
    27. --本月记录 SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=0   
    28. --本周记录 SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=0   
    29. --包括本年这些查询方式是一样的  
    30.   
    31. sql server中的时间函数  
    32. 1.   当前系统日期、时间  
    33.      select getdate()   
    34. 2. dateadd   在向指定日期加上一段时间的基础上,返回新的 datetime 值  
    35.     例如:向日期加上2天  
    36.     select dateadd(day,2,'2004-10-15')   --返回:2004-10-17 00:00:00.000  
    37. 3. datediff 返回跨两个指定日期的日期和时间边界数。  
    38.     select datediff(day,'2004-09-01','2004-09-18')    --返回:17  
    39. 4. datepart 返回代表指定日期的指定日期部分的整数。  
    40.    SELECT DATEPART(month'2004-10-15')   --返回 10  
    41. 5. datename 返回代表指定日期的指定日期部分的字符串  
    42.     SELECT datename(weekday, '2004-10-15')   --返回:星期五  
    43. 6. day(), month(),year() --可以与datepart对照一下  
    44. select 当前日期=convert(varchar(10),getdate(),120),当前时间=convert(varchar(8),getdate(),114)  
    45. select datename(dw,'2004-10-15')  
    46. select 本年第多少周=datename(week,'2004-10-15')  
    47.        ,今天是周几=datename(weekday,'2004-10-15')  
    48.   
    49. 函数 参数/功能   
    50. GetDate( ) 返回系统目前的日期与时间   
    51. DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 与date1两个日期之间的差值 date2-date1   
    52. DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期   
    53. DatePart (interval,date) 返回日期date中,interval指定部分所对应的整数值   
    54. DateName (interval,date) 返回日期date中,interval指定部分所对应的字符串名称  
    55. 参数 interval的设定值如下:  
    56. 值 缩 写(Sql Server) Access 和 ASP 说明   
    57. Year Yy yyyy 年 1753 ~ 9999   
    58. Quarter Qq q   季 1 ~ 4   
    59. Month Mm m   月1 ~ 12   
    60. Day of year Dy y 一年的日数,一年中的第几日 1-366   
    61. Day Dd d   日,1-31   
    62. Weekday Dw w 一周的日数,一周中的第几日 1-7   
    63. Week Wk ww 周,一年中的第几周 0 ~ 51   
    64. Hour Hh h   时0 ~ 23   
    65. Minute Mi n 分钟0 ~ 59   
    66. Second Ss s 秒 0 ~ 59   
    67. Millisecond Ms - 毫秒 0 ~ 999  
    68.   
    69. access 和 asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,这些函数的用法也类似  
    70.   
    71. 举例:  
    72. 1.GetDate() 用于sql server :select GetDate()  
    73. 2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值为 514592 秒  
    74. DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值为 5 天  
    75. 3.DatePart('w','2005-7-25 22:56:32')返回值为 2 即星期一(周日为1,周六为7)  
    76. DatePart('d','2005-7-25 22:56:32')返回值为 25即25号  
    77. DatePart('y','2005-7-25 22:56:32')返回值为 206即这一年中第206天  
    78. DatePart('yyyy','2005-7-25 22:56:32')返回值为 2005即2005年  
    79.   
    80. 判断表存在不存在:   
    81. select   count(*)   from   sysobjects   where   type='U'   and   name='你的表名'   
    82. 判断字段存在不存在:   
    83. select   count(*)   from   syscolumns   
    84. where   id       =   (select   id   from   sysobjects   where   type='U'   and   name='你的表名')      
    85. and       name   =   '你要判断的字段名'  
    86.   
    87. //SQL当前日期获取技巧  
    88. 一个月第一天的SQL 脚本:  
    89.      SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)  
    90. 本周的星期一  
    91.      SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)  
    92. 一年的第一天  
    93.      SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)  
    94. 季度的第一天  
    95.      SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)  
    96. 当天的半夜  
    97.      SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)  
    98. 上个月的最后一天  
    99.       SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))  
    100. 去年的最后一天  
    101.      SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))  
    102. 本月的最后一天  
    103.      SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))  
    104. 本年的最后一天  
    105.      SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。  
    106. 本月的第一个星期一  
    107.      select DATEADD(wk, DATEDIFF(wk,0, dateadd(dd,6-datepart(day,getdate()),getdate())), 0)  
    108. sql得到当前系统时间得 日期部分  
    109. CONVERT(varchar(10),getDate(),120)  
    110.   
    111.    
    112.   
    113. 求得到"昨天,今天"日期函数的SQL  
    114.   
    115.   
    116. 所属分类:MS-SQL Server 基础类  
    117.   
    118.    
    119.   
    120. 1.只要日期部分,时间部分不要  
    121.   
    122. select convert(varchar(10),getdate(),120)  
    123.   
    124. 2.求以下日期SQL:  
    125.   
    126. 昨天   
    127.   
    128. select convert(varchar(10),getdate() - 1,120)  
    129.   
    130. 明天  
    131.   
    132. select convert(varchar(10),getdate() + 1,120)  
    133.   
    134. 最近七天  
    135.   
    136. select * from tb where 时间字段 >= convert(varchar(10),getdate() - 7,120)  
    137.   
    138. 随后七天  
    139.   
    140. select * from tb where 时间字段 <= convert(varchar(10),getdate() + 7,120) and 时间字段 >= 时间字段  
    141.   
    142. 上月  
    143.   
    144. select * from tb where month(时间字段) = month(getdate()) - 1  
    145.   
    146. 本月  
    147.   
    148. select * from tb where month(时间字段) = month(getdate())  
    149.   
    150. 下月  
    151.   
    152. select * from tb where month(时间字段) = month(getdate()) + 1  
    153.   
    154. 本周  
    155.   
    156. select * from tb where datediff(week , 时间字段 ,getdate()) = 0  
    157.   
    158. 上周  
    159.   
    160. select * from tb where datediff(week , 时间字段 ,getdate()) = 1  
    161.   
    162. 下周  
    163.   
    164. select * from tb where datediff(week , 时间字段 ,getdate()) = -1  
    165.   
    166.   
    167. --------------------------------------------------------  
    168.   
    169. 昨天:dateadd(day,-1,getdate())  
    170.   
    171. 明天:dateadd(day,1,getdate())  
    172.   
    173. 上月:month(dateadd(month, -1, getdate()))  
    174.   
    175. 本月:month(getdate())  
    176.   
    177. 下月:month(dateadd(month, 1, getdate()))   
    178. 我的网站地址:http://www.jixie.net

你可能感兴趣的:(sql)