关于时间处理的SQL语句

需求:比较两个时间是否在同一天。

分析:

date变量之间的逻辑运算单位为天,无法比较两个日期变量是否在同一天,有一个名为trunc的sql函数,已经具备处理时间的很多功能,比如说获取一个时间变量的年月日、返回当月第一天等等。


解答: 

                            select trunc(a.date)-trunc(b.date)<>0 from dual; 


下面列举该函数的其他用法。

 --Oracle trunc()函数的用法
/**************日期********************/
1.select trunc(sysdate) from dual  --2011-3-18  今天的日期为2011-3-18
2.select trunc(sysdate, 'mm')   from   dual  --2011-3-1    返回当月第一天.
3.select trunc(sysdate,'yy') from dual  --2011-1-1       返回当年第一天
4.select trunc(sysdate,'dd') from dual  --2011-3-18    返回当前年月日
5.select trunc(sysdate,'yyyy') from dual  --2011-1-1   返回当年第一天
6.select trunc(sysdate,'d') from dual  --2011-3-13 (星期天)返回当前星期的第一天
7.select trunc(sysdate, 'hh') from dual   --2011-3-18 14:00:00   当前时间为14:41  
8.select trunc(sysdate, 'mi') from dual  --2011-3-18 14:41:00   TRUNC()函数没有秒的精确
/***************数字********************/
/*
TRUNC(number,num_digits)
Number 需要截尾取整的数字。
Num_digits 用于指定取整精度的数字。Num_digits 的默认值为 0。
TRUNC()函数截取时不进行四舍五入
*/
9.select trunc(123.458) from dual --123
10.select trunc(123.458,0) from dual --123
11.select trunc(123.458,1) from dual --123.4
12.select trunc(123.458,-1) from dual --120
13.select trunc(123.458,-4) from dual --0
14.select trunc(123.458,4) from dual  --123.458
15.select trunc(123) from dual  --123
16.select trunc(123,1) from dual --123
17.select trunc(123,-1) from dual --120

<注:摘自http://www.cnblogs.com/xiaoyudz/archive/2011/03/18/1988467.html>


转载于:https://www.cnblogs.com/iosDevZhong/p/4395232.html

  • 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、付费专栏及课程。

余额充值