1.MyBatis3做數(shù)據(jù)持久層,在字段中有Date和DateTime類型,在插入數(shù)據(jù)時只要將實體的屬性設(shè)置成Timestamp就會對應(yīng)mysql的DateTime類型,Date會對應(yīng)mysql的Date類型。
我們提供的服務(wù)有:做網(wǎng)站、網(wǎng)站設(shè)計、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、舞陽ssl等。為近千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的舞陽網(wǎng)站制作公司
2.在MyBatis映射文件中要表明映射類型。
result column="modified_date" jdbcType="TIMESTAMP" property="modifiedDate" javaType="java.sql.Timestamp" /
result column="create_date" jdbcType="DATE" property="createDate" javaType="java.util.Date" /
result column="date" jdbcType="TIMESTAMP" property="date" javaType="java.util.Date" /
3.在插入語句的那個mybatis XML文件在使用字段的時候也要標(biāo)明類型,注意得用#{},別用${}
#{modifiedDate, jdbcType=TIMESTAMP}
#{createDate, jdbcType=DATE}。
java中有date和datetime,mysql中也有date和datetime,這里我們來說說mysql中的date和datetime。
1 mysql中的date和datetime
1.1 DATETIME
類型可用于需要同時包含日期和時間信息的值。MySQL 以:
‘YYYY-MM-DD HH:MM:SS’
格式檢索與顯示 DATETIME 類型。支持的范圍是:
‘1000-01-01 00:00:00’
到
‘9999-12-31 23:59:59’。
(“支持”的含義是,盡管更早的值可能工作,但不能保證他們均可以。)
1.2 DATE
類型可用于需要一個日期值而不需要時間部分時。MySQL 以
‘YYYY-MM-DD’
格式檢索與顯示DATE值。支持的范圍則是
‘1000-01-01’
到
‘9999-12-31’。
2 與java數(shù)據(jù)的交互
能看出來mysql中的date和datetime區(qū)別還是挺大的,date沒有保存時間。但是java中的date(java.util.Date)記錄的還是挺細(xì)的,日期和時間都可以記下來,那么現(xiàn)在問題來了,如果想在mysql中存儲日期和時間,也就是用datetime,而在數(shù)據(jù)中應(yīng)該如何對應(yīng)呢?
我使用hibernate測了一下,發(fā)現(xiàn)當(dāng)把mysql數(shù)據(jù)庫中設(shè)置了datetime,反向工程生成的hbm.xml文件中,使用的是timestamp,如下:
property name="Publishdate" column="publishdate" type="timestamp" not-null="false" length="10" /1
反向生成java的pojo時,生成的還是Date。
由此可見對于mysql中datetime,與java中的date,如果要使二者正確交互,中間要使用timestamp。
如果要在JAVA中直接插入MySql的datetime類型,則可以使用:
Date date = new Date();
Timestamp timeStamp = new Timestamp(date.getTime());12
再用setTimestamp()設(shè)置數(shù)據(jù)庫中的“日期+時間”。
這樣放入數(shù)據(jù)庫的就是“yyyy-mm-dd hh:mm:ss”格式的數(shù)據(jù)。
注意,mysql中如果使用date而不是datetime是保存不下“日期+時間”的,只能保存“時間”。
你好啊。我又來了 NOW()函數(shù)以`'YYYY-MM-DD HH:MM:SS'返回當(dāng)前的日期時間,可以直接存到DATETIME字段中。
CURDATE()以’YYYY-MM-DD’的格式返回今天的日期,可以直接存到DATE字段中。
CURTIME()以’HH:MM:SS’的格式返回當(dāng)前的時間,可以直接存到TIME字段中。
例:insert into tablename (fieldname) values (now())
分享文章:mysql怎么存入時間 mysql存入當(dāng)前時間
轉(zhuǎn)載來于:http://jinyejixie.com/article40/ddopoeo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、網(wǎng)站排名、定制開發(fā)、營銷型網(wǎng)站建設(shè)、服務(wù)器托管、網(wǎng)站設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)