【SSH商城】——Date、String、Timestamp之间的转换

  小编最近在做商城项目,其中遇到了一个问题就是向数据库中插入数据插不进去,为此很是一番苦战!

 【错误提示】

  org.springframework.dao.DataIntegrityViolationException:could not insert: [com.gxa.bj.order.vo.Order]; SQLinsert into orders (total, ordertime, state, name, addr, phone, uid) values(?, ?, ?, ?, ?, ?, ?) nested exception isorg.hibernate.exception.DataException: could not insert:[com.gxa.bj.order.vo.Order]

  ERROR JDBCExceptionReporter:234 - Data truncation: Incorrectdatetime value: '' for column 'ordertime' at row 1

【解决方案】

 遇到问题后查到了几种解决方案:

方法一:

   在jdbc里添加“&useOldAliasMetadataBehavior=true” ,添加了以后还是没有解决,排除!

方法二:

    错误原因:一般是数据库表中的字段包含了数据库的关键字(保留字)
    处理方法:修改数据库中和关键字产生冲突的字段名,重新映射字段名和bean中的类名

    查询了一下发现没有冲突的字段名,排除!

 方法三:

    对ordertime使用SimpleDateFormat进行转换,转换成和数据库一致的格式:yyyy-MM-dd hh:mm:ss。通过这种方法完美的解决了问题微笑

  原码: 

//生成订单方法
public String save() throws ParseException{
//保存数据到时数据库
//订单数据加入
 order.setOrdertime(date3);
 改后的代码:

//生成订单方法
public String save() throws ParseException{
//保存数据到时数据库
//订单数据加入
//转化时间格式
    Date date=new Date();
    DateFormat temp=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");  
         String date1=temp.format(date); 
         try { 
        	 date=temp.parse(date1);
         } catch (Exception e) {  e.printStackTrace();  } 
         order.setOrdertime(date);
 通过遇到的这个问题小编我来说说今天的主题:

【Date、String、Timestamp之间的转换】

 一、String与Date(java.util.Date)互转

  1、String ——> Date

      String dateStr = "2010/05/04 12:34:23";   
        Date date = new Date();   
        //注意format的格式要与日期String的格式相匹配   
        DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   
        try {   
            date = sdf.parse(dateStr);   
            System.out.println(date.toString());   
        } catch (Exception e) {   
            e.printStackTrace();   
        }  

  2、Date   ——> String

       String dateStr = "";   
        Date date = new Date();   
        //format的格式可以任意   
        DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   
        DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");   
        try {   
            dateStr = sdf.format(date);   
            System.out.println(dateStr);   
            dateStr = sdf2.format(date);   
            System.out.println(dateStr);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }  

   日期向字符串转换,可以设置任意的转换格式format,使任意类型的数据转换成一个字符串。

 二、String与Timestamp互转

  1、String ——>Timestamp

  使用Timestamp的valueOf()方法

 Timestamp ts = new Timestamp(System.currentTimeMillis());   
        String tsStr = "2011-05-09 11:49:45";   
        try {   
            ts = Timestamp.valueOf(tsStr);   
            System.out.println(ts);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }  
注:String的类型必须形如: yyyy-mm-dd hh:mm:ss[.f...] 这样的格式,中括号表示可选,否则报错!!!

    如果String为其他格式,可考虑重新解析下字符串,再重组~~

  2、Timestamp ——>String

  使用Timestamp的toString()方法或者借用DateFormat

Timestamp ts = new Timestamp(System.currentTimeMillis());   
        String tsStr = "";   
        DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   
        try {   
            //方法一   
            tsStr = sdf.format(ts);   
            System.out.println(tsStr);   
            //方法二   
            tsStr = ts.toString();   
            System.out.println(tsStr);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }
  很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式

 三、Date( java.util.Date )和Timestamp互转

      声明:查API可知,Date和Timesta是父子类关系

 1、Timestamp ——> Date

   Timestamp ts = new Timestamp(System.currentTimeMillis());   
        Date date = new Date();   
        try {   
            date = ts;   
            System.out.println(date);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }

 2、Date——>  Timestamp

    父类不能直接向子类转化,可借助中间的String~~~~

【总结】

 1、java.sql.Date 只存储日期数据不存储时间数据

// 会丢失时间数据
preparedStatement.setDate(1, new java.sql.Date(date.getTime()));
//可以这样来处理
preparedStatement.setTimestamp(1, new java.sql.Timestamp(new java.util.Date().getTime()));
//想要得到完整的数据,包括日期和时间,可以这样
java.util.Date d = resultSet.getTimestamp(1);
//这样处理更合适一些,可以避免一些潜在Timestamp 问题
java.util.Date d = new java.util.Date(resultSet.getTimestamp(1).getTime());
 2、往数据库存储的时候可以接收 java.util.Date类型 再用getTime()方法得到代表那个Date对象的long值,再以这个long值 构造一个Timestamp对象 存进数据库中。
 3、从存数据库里取的时候,可以先得到Timestamp用他的getTime()方法得到long值,再以这个long值构造一个java.util.Date对象,这样就可以对这个Date对象操作了。不如说 new SimpleTimeFormat("yyyyy-MM-dd HH:mm:ss").format()等等






  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值