关于日期处理的 sql语句

SELECT DATEDIFF(mm,'2014-10-5',GETDATE()) -- 0 表示当月
  SELECT DATEDIFF(mm,'2014-9-5',GETDATE()) -- 1 表示前1个月
  SELECT DATEDIFF(mm,'2014-1-5',GETDATE()) -- 9 表示前9个月
  SELECT CONVERT(datetime,CONVERT(char(8),GETDATE(),120)+'1') -- 取本月第一天 2014-10-01 00:00:00.000
  select dateadd(d,-day(getdate()),dateadd(m,1,getdate())) -- 取本月第后一天 2014-10-31 14:10:34.890

  select dateadd(d,-day('2014-03-05 10:12:24'),dateadd(m,1,'2014-03-05 10:12:24')) -- 取这个月第后一天   2014-03-31 10:12:24.000
  SELECT CONVERT(datetime,CONVERT(char(8),'2014-03-05 10:12:24',120)+'1') -- 取本月第一天 2014-03-01 00:00:00.000


   select YEAR('2008-11-2 00:00:00')  --年
   select MONTH('2008-11-2 00:00:00')  --月
   select DAY('2008-11-2 00:00:00')  --日


  DECLARE @dDate DATETIME
  DECLARE @dStartDate DATETIME
  DECLARE @dEndDate DATETIME

  SET @dDate='2014-03-05 10:12:24'
  SELECT @dStartDate=CONVERT(DATETIME,CONVERT(CHAR(8),@dDate,120)+'1') -- 取本月第一天 2014-03-01 00:00:00.000
  SELECT @dEndDate=DATEADD(d,-DAY(@dDate),DATEADD(m,1,@dDate)) -- 取这个月第后一天   2014-03-31 10:12:24.000
  SELECT CONVERT(VARCHAR,MONTH(@dStartDate)) + '月' + CONVERT(VARCHAR,DAY(@dStartDate)) + '日' + '-' +
      CONVERT(VARCHAR,MONTH(@dEndDate)) + '月' + CONVERT(VARCHAR,DAY(@dEndDate)) + '日'   -- 3月1日-3月31日




  SELECT CONVERT(datetime,CONVERT(char(8),GETDATE(),120)+'1')--这月的第一天  
 select dateadd(d,-day(getdate()),dateadd(m,1,getdate()))--这月的最后一天   
 SELECT DATEADD(mm,DATEDIFF(mm,0,dateadd(month,-1,getdate())),0)--上月第一天  
 select dateadd(ms,-3,DATEADD(mm,DATEDIFF(mm,0,getdate()),0))--上月最后一天 
 select DATEADD(SS,-1,dateadd(day,1,CONVERT(varchar(15) , getdate(), 102 )))--获取当天的最后一刻  
<p> </p><p>SELECT DATEADD(mm,DATEDIFF(mm,0,dateadd(month,-1,getdate())),0)--上月第一天   
 
 select dateadd(ms,-3,DATEADD(mm,DATEDIFF(mm,0,getdate()),0))--上月最后一天 </p><p> select datediff(dd,getdate(),dateadd(mm,1,getdate())) -- 计算当月共有多少天
 </p><p> select datediff(dd,
  DATEADD(mm,DATEDIFF(mm,0,dateadd(month,-1,getdate())),0) ,  
  dateadd(ms,-3,DATEADD(mm,DATEDIFF(mm,0,getdate()),0)) ) + 1  -- 计算上个月共有多少天</p>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
处理SQL语句的时间格式化时,可以使用JSqlParser这个库来解析SQL语句并提取其中的要素。首先,通过`CCJSqlParserUtil.parse(sqlStr)`方法将SQL语句解析为一个`Statement`对象。然后,可以使用`instanceof`关键字来判断该语句是否为SELECT语句,并进一步提取其中的要素。 例如,可以通过以下代码来获取SELECT语句中的时间格式化处理: ```java Statement statement = CCJSqlParserUtil.parse(sqlStr); if (statement instanceof Select) { Select select = (Select) statement; PlainSelect plainSelect = (PlainSelect) select.getSelectBody(); SelectExpressionItem selectExpressionItem = (SelectExpressionItem) plainSelect.getSelectItems().get(0); // 获取时间格式化处理的表达式 String dateFormatExpression = selectExpressionItem.getExpression().toString(); // 进行相应的时间格式化处理 // ... } ``` 另外,JSqlParser还提供了一些有用的功能,例如格式化SQL语句、生成SQL查询等。可以通过与其他Java库和框架集成,如Hibernate、Spring等,来进一步扩展其功能。你可以在项目地址\[2\]中找到更多关于JSqlParser的详细信息和用法示例。 #### 引用[.reference_title] - *1* *2* [Java中如何解析SQL语句、格式化SQL语句、生成SQL语句?](https://blog.csdn.net/dyc87112/article/details/129375727)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [sql日期格式化](https://blog.csdn.net/persistence_PSH/article/details/121625711)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值