获取当前月的第一天和最后一天...

本文介绍了一种在SQL中获取昨天及月初日期的方法。通过使用T-SQL的DATEADD和GETDATE函数,结合CONVERT函数进行格式转换,实现了日期的灵活操作。

set @F_d = convert(varchar(10),dateadd(dd,-day(getdate())+1,getdate()),120)
set @E_d = convert(varchar(10),dateadd(dd,-day(getdate()),dateadd(m,1,getdate())),120)

### 使用Java `LocalDateTime` 获取当前份的第一天最后一天 为了获取当前份的第一天最后一天的时间戳,可以使用 Java 8 中引入的 `LocalDateTime` `TemporalAdjusters` 工具类。以下是具体实现方法: #### 方法一:使用 `TemporalAdjusters` 通过 `TemporalAdjusters` 可以方便地调整日期时间对象到特定的位置。 ```java import java.time.LocalDate; import java.time.LocalDateTime; import java.time.LocalTime; import java.time.temporal.TemporalAdjusters; public class Main { public static void main(String[] args) { LocalDate today = LocalDate.now(); // 获取第一天的 LocalDateTime 对象 LocalDateTime startOfMonth = LocalDateTime.of( today.with(TemporalAdjusters.firstDayOfMonth()), LocalTime.MIN); // 获取最后一天的 LocalDateTime 对象 LocalDateTime endOfMonth = LocalDateTime.of( today.with(TemporalAdjusters.lastDayOfMonth()), LocalTime.MAX); System.out.println("Start of month: " + startOfMonth); System.out.println("End of month: " + endOfMonth); } } ``` 这段代码创建了两个 `LocalDateTime` 实例来表示一个的第一个时刻最后一个时刻[^1]。 #### 方法二:手动构建日期 另一种方式是直接指定年份、份并设置日部分为固定值(即每首日设为1号),对于末则继续借助 `TemporalAdjusters` 来自动计算该的最大天数。 ```java import java.time.LocalDate; import java.time.LocalDateTime; import java.time.Month; import java.time.YearMonth; import java.time.LocalTime; public class Main { public static void main(String[] args) { YearMonth currentYearMonth = YearMonth.from(LocalDate.now()); // 构建当第一天的 LocalDateTime 对象 LocalDateTime startOfMonth = LocalDateTime.of(currentYearMonth.getYear(), currentYearMonth.getMonth(), 1, 0, 0, 0); // 构建当最后一天的 LocalDateTime 对象 int lastDay = currentYearMonth.lengthOfMonth(); LocalDateTime endOfMonth = LocalDateTime.of(currentYearMonth.getYear(), currentYearMonth.getMonth(), lastDay, 23, 59, 59); System.out.println("Start of month: " + startOfMonth); System.out.println("End of month: " + endOfMonth); } } ``` 这种方法同样能够得到相同的结果,不过更直观一些,在某些场景下可能更容易理解[^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值