xjtusoftware
2010-03-11 17:39
浏览 156
已采纳

请问为什么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">


  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • iteye_13500 2010-03-11 18:20
    已采纳

    第一个
    [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的设计有很多问题,象这里这样的设计也是不太好的。

    点赞 打赏 评论
  • iteye_13500 2010-03-11 18:22

    简单的说,你从数据库取出来的是java.sql.Date类型,设置后成了java.util.Date类型,类型不同,调用的toString方法不同,造成输出结果不同。

    点赞 打赏 评论
  • iteye_13500 2010-03-11 19:52

    [quote]多谢多谢。 我刚打印了class,确实是这种问题,两次获取的数据的类型前者是java.sql.Date,后者是java.util.Date.但不知为何会出现这种现象?同时实体对象的get方法,为何两次的结果不同?是不是和之间的重新setDate有关? [/quote]

    pp = p;
    pp.getCard().setValDate(new Date(160, 11, 31));

    因为你进行了set操作,pp操作的就是p。

    点赞 打赏 评论

相关推荐 更多相似问题