java中的DateTime的具體使用
引入org.joda.time.DateTime
<dependency> ? ?<groupId>joda-time</groupId> ? ?<artifactId>joda-time</artifactId> ? ?<version>2.9.8</version> </dependency>
1.初始化時(shí)間
DateTime time = new DateTime(2018,4,23,23, 7,18,888); // 2018年4月23日23點(diǎn)7分18秒888毫秒 ?
2.按格式輸出時(shí)間(將DateTime格式轉(zhuǎn)換為字符串)
String time = dateTime.toString("yyyy-MM-dd hh:mm:ss.SSSa");
小寫hh是12小時(shí)制,大寫HH是24小時(shí)制
3.將字符串轉(zhuǎn)換為DateTime格式
DateTimeFormatter format = DateTimeFormat .forPattern("yyyy-MM-dd HH:mm:ss"); ?
DateTime dateTime = DateTime.parse("2018-4-23 23:12:16", format);?4.取得當(dāng)前時(shí)間
DateTime time= new DateTime();
5.計(jì)算兩個(gè)日期間隔的天數(shù)
?LocalDate start=new LocalDate(2018,4,23); ? ? ?LocalDate end=new LocalDate(2019, 06, 16); ? ? ?int days = Days.daysBetween(start, end).getDays();?
6.增加日期
? ? ? DateTime dateTime = DateTime.parse("2018-04-23"); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusDays(1); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusHours(2); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusMinutes(3); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusMonths(4); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusSeconds(5); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusWeeks(6); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.plusYears(7); ?7.減少日期
? DateTime dateTime = DateTime.parse("2018-04-23"); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.minusMillis(1); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.minusHours(1); ?
? ? ? ? ? ? ? ? dateTime = dateTime1.minusSeconds(1);8.判斷是否閏月
DateTime time = new DateTime();
org.joda.time.DateTime.Property month = time.monthOfYear();
System.out.println("是否閏月:" + month.isLeap());
9.DateTime與Date轉(zhuǎn)換
DateTime time = new DateTime(new Date()); Date date = time.toDate(); DateTime time2 = new DateTime(System.currentTimeMillis()); time2.getMillis();
10.DateTime與Calendar轉(zhuǎn)換
Calendar calendar = Calendar.getInstance();
補(bǔ)充:
字符串和java.utils.Date相互轉(zhuǎn)換
字符串轉(zhuǎn)化為Date類型
DateFormat format = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss"); ? ?// 這里填寫的是想要進(jìn)行轉(zhuǎn)換的時(shí)間格式
String str = "2016-12-11 17:17:10"; ? ? ? ? // 時(shí)間字符串
java.utils.Date date = null;
try{
date = format.parse(str);
}catch(Exception e){
e.printStackTrace();
}
?Date類型轉(zhuǎn)化為字符串
DateFormat format = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss"); ? ?// 這里填寫的是想要進(jìn)行轉(zhuǎn)換的時(shí)間格式
Date date = new java.utils.Date(); ? ? ?// 獲取當(dāng)前時(shí)間
String str = format.format(date);
// str = "2016-12-11 17:17:10"java.sql.Date向數(shù)據(jù)庫(kù)寫入日期
這里就需要java.sql.Date和java.utils.Date進(jìn)行相互轉(zhuǎn)換了,這個(gè)轉(zhuǎn)換一般比較容易,利用構(gòu)造方法和.getTime() 方法進(jìn)行轉(zhuǎn)化。
java.utils.Date date = new java.utils.Date(); ? // 獲取當(dāng)前時(shí)間 java.sql.Date sql_date = new java.sql.Date(date.getTime()); //轉(zhuǎn)換成java.sql.Date
接著使用PreparedStatement 向數(shù)據(jù)庫(kù)中寫入時(shí)間,即可。
ps.setDate(1, new java.sql.Date(date.getTime())); // 設(shè)置項(xiàng)
java.sql.Timestamp向數(shù)據(jù)庫(kù)中寫入時(shí)間
需要注意的是,上邊一種方法只能將日期寫入到數(shù)據(jù)庫(kù)中,為了能夠?qū)r(shí)間精確到s甚至是ms。我們需要使用java.sql.Timestamp 類型。
java.sql.Timestamp 類型的構(gòu)造函數(shù)也可以使用Long進(jìn)行初始化
Date date = new Date(); Timestamp timeStamp = new Timestamp(date.getTime());
故在生成java.utils.Date時(shí),將時(shí)間精確到s,然后使用預(yù)編譯語(yǔ)句執(zhí)行SQL語(yǔ)句
Date date = new Date();
Timestamp timeStamp = new Timestamp(date.getTime());
sql= "insert into flowmeter2(total,std_flow,temp,press,time) values(?,?,?,?,?)";
try {
PreparedStatement ps = connection.prepareStatement(sql);
ps.setString(1, total);
ps.setString(2, std_flow);
ps.setString(3, temp);
ps.setString(4, press);
ps.setTimestamp(5, timeStamp);
ps.executeUpdate();
System.out.println("添加成功!");
connection.close();
到此這篇關(guān)于java中的DateTime的具體使用的文章就介紹到這了,更多相關(guān)java DateTime使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
nacos-discovery包名層級(jí)問(wèn)題解決
這篇文章主要為大家介紹了nacos-discovery包名層級(jí)問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
分析設(shè)計(jì)模式之模板方法Java實(shí)現(xiàn)
所謂模板方法模式,就是一個(gè)對(duì)模板的應(yīng)用,就好比老師出試卷,每個(gè)人的試卷都是一樣的,這個(gè)原版試卷就是一個(gè)模板,可每個(gè)人寫在試卷上的答案都是不一樣的,這就是模板方法模式。它的主要用途在于將不變的行為從子類搬到超類,去除了子類中的重復(fù)代碼2021-06-06
spring boot 下對(duì)JSON返回值去除null和空字段操作
這篇文章主要介紹了spring boot 下對(duì)JSON返回值去除null和空字段操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
hibernate 配置數(shù)據(jù)庫(kù)方言的實(shí)現(xiàn)方法
這篇文章主要介紹了hibernate 配置數(shù)據(jù)庫(kù)方言的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
mybatis-plus用insertBatchSomeColumn方法批量新增指定字段
mybatisPlus底層的新增方法是一條一條的新增的,下面這篇文章主要給大家介紹了關(guān)于mybatis-plus用insertBatchSomeColumn方法批量新增指定字段的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05
java獲取當(dāng)前時(shí)間并格式化代碼實(shí)例
這篇文章主要介紹了java獲取當(dāng)前時(shí)間并格式化代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08

