mysql的时间日期存储格式如下:
year xxxx(年)
time xx:xx:xx(时分秒) 只表示时间
date xxxx-xx-xx(年月日) 只表示日期
datetime xxxx-xx-xx xx:xx:xx(年月日 时分秒) 表示日期和时间
timestamp xxxx-xx-xx xx:xx:xx(年月日 时分秒) 精确表示日期和时间
java中的时间日期表示:
java.util.Date
java.sql.Date
java.sql.Time
java.sql.Timestamp
后面这三个类继承自java.util.Date, 扩展了其功能
java使用这三个类型与mysql交互更为方便
java.sql.Date 只读取日期
java.sql.Time 只读取时间
java.sql.Timestamp 读取日期和时间
Timestamp
测试, 数据库存放的datetime字段的某个值是 : "2001-12-15 12:30:59"
实体类中使用String接收到的是: "2001-12-15 12:30:59.0" (即默认会带上 ' .0 ')
使用TimeStamp接收到的是其长整型(即表示时间的是一串数字)
1.如果使用TimeStamp接收, 可以使用SimpleDateSormat格式化为String
// 获取TimeStamp的长整型表现形式
long datetime = song.getSize().getTime();
SimpleDateFormat sdf = new SimpleDateFormat("yyy-MM-dd HH:mm:ss");
String str = sdf.format(datetime);
但是有一个问题, 既然实体中使用的是TimeStamp类型(这个类型转换为String表示时, 默认在后面加上: '.0')
而实体对象中TimeStamp的值, 是这样: "2001-12-15 12:30:59.0",
并没有改变实体对象中TimeStamp的值
如果要返回这个实体对象, 则不能准备表示数据库中此数据(即:"2001-12-15 12:30:59")
我可以使用格式化后的String数据, 重新封装为新类型的对象, 再返回新对象(麻烦在于重新创建类型)
2.如果用的String接收, 可以对String截取, 这样简便很多
@RequestMapping("/getSongBySongId")
@ResponseBody
public Object test() {
List<Song> s = dao.findAll();
for (Song song : s) {
String size = song.getSize();
// 从0开始截取到这个点的位置
String newSize = size.substring(0, size.lastIndexOf("."));
// 重新设置实体对象的size属性
song.setSize(newSize);
}
return s;
}
总结:
- 数据库使用date, java实体类推荐使用java.sql.Date接收
- 数据库使用time, java实体类推荐使用java.sql.Time接收
- 数据库使用datetime, java实体类推荐使用String接收
由于实体类与mysql如上面对应, 在向mysql插入记录的时候:
public void insertTest() throws ParseException {
Song s = new Song();
s.setSong_name("呵呵");
String d = "00:03:05"; // 构建日期/时间格式的String
SimpleDateFormat f = new SimpleDateFormat("hh:mm:ss");
long lo = f.parse(d).getTime();
Time time = new Time(lo);
s.setSize(time);
dao.save(s);
}
date类型也是一样的操作, 而datetime则最简单(直接用String)
本人自己摸索时, 还没找到更好的办法处理日期时间办法, 但目前 日期/时间 的读写按这样做是可行的
如果忽略实体中的日期/时间类型, 全部按String来存储
经过测试, 这样对mysql的读写操作完全没有问题, 而且还更加简单, 也许应该这样做