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的读写操作完全没有问题, 而且还更加简单, 也许应该这样做