请问为什么EJB3.0 持久化过程中一个jsp页面的Date的输出格式不相同?

最近在学校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。