最近在学校entitybean,写了一个相关的jsp,从mysql中读取数据,数据库表中的时间的格式是Date,而后在jsp中获取这个实体实例,然后get时间,将其输出。实体类中用的也是Date类型,但在jsp中,两次的时间的输出格式不同,谁能告诉我为什么会不同?
第一次显示为:身份证有效期 :2060-12-31
第二次显示为:身份证有效期 :Fri Dec 31 00:00:00 CST 2060
WHO know why?
附jsp页面代码:
<%@ page contentType="text/html;charset=GBK" language="java"
import="java.util.*,javax.naming.*,entitybean.Person,statelessbean.PersonDaoLocal,pojo.MyInfo"
pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme() + "://"
+ request.getServerName() + ":" + request.getServerPort()
+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
第一个
[code="java"]out.println("
身份证有效期 :" + p.getCard().getValDate()); [/code]
中,取出来的Date其实是java.sql.Date,这一点我也觉得诡异,你可以使用:
[code="java"]out.println(p.getCard().getValDate().getClass());[/code]
打印出来看。
虽然你实体类中定义的Date是java.util.Date,但是看java.sql.Date的定义
[code="java"]public class Date extends java.util.Date[/code]
其实java.sql.Date类是java.util.Date的子类,所以这里取出来的Date是java.sql.Date语法上是没有问题的。
当你调用
[code="java"]pp.getCard().setValDate(new Date(160, 11, 31)); [/code]
后,Date的类型转换了,由于类型不同,打印时调用的toString()的方法也不同,造成格式不同。
顺便说一句,java.util.Date的设计有很多问题,象这里这样的设计也是不太好的。
简单的说,你从数据库取出来的是java.sql.Date类型,设置后成了java.util.Date类型,类型不同,调用的toString方法不同,造成输出结果不同。
[quote]多谢多谢。 我刚打印了class,确实是这种问题,两次获取的数据的类型前者是java.sql.Date,后者是java.util.Date.但不知为何会出现这种现象?同时实体对象的get方法,为何两次的结果不同?是不是和之间的重新setDate有关? [/quote]
pp = p;
pp.getCard().setValDate(new Date(160, 11, 31));
因为你进行了set操作,pp操作的就是p。