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ù)庫寫入日期
這里就需要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ù)庫中寫入時(shí)間,即可。
ps.setDate(1, new java.sql.Date(date.getTime())); // 設(shè)置項(xiàng)
java.sql.Timestamp向數(shù)據(jù)庫中寫入時(shí)間
需要注意的是,上邊一種方法只能將日期寫入到數(shù)據(jù)庫中,為了能夠?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ù)編譯語句執(zhí)行SQL語句
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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
分析設(shè)計(jì)模式之模板方法Java實(shí)現(xiàn)
所謂模板方法模式,就是一個(gè)對(duì)模板的應(yīng)用,就好比老師出試卷,每個(gè)人的試卷都是一樣的,這個(gè)原版試卷就是一個(gè)模板,可每個(gè)人寫在試卷上的答案都是不一樣的,這就是模板方法模式。它的主要用途在于將不變的行為從子類搬到超類,去除了子類中的重復(fù)代碼2021-06-06spring boot 下對(duì)JSON返回值去除null和空字段操作
這篇文章主要介紹了spring boot 下對(duì)JSON返回值去除null和空字段操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10hibernate 配置數(shù)據(jù)庫方言的實(shí)現(xiàn)方法
這篇文章主要介紹了hibernate 配置數(shù)據(jù)庫方言的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05mybatis-plus用insertBatchSomeColumn方法批量新增指定字段
mybatisPlus底層的新增方法是一條一條的新增的,下面這篇文章主要給大家介紹了關(guān)于mybatis-plus用insertBatchSomeColumn方法批量新增指定字段的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05java獲取當(dāng)前時(shí)間并格式化代碼實(shí)例
這篇文章主要介紹了java獲取當(dāng)前時(shí)間并格式化代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08