小编最近在做商城项目,其中遇到了一个问题就是向数据库中插入数据插不进去,为此很是一番苦战!
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” ,添加了以后还是没有解决,排除!
查询了一下发现没有冲突的字段名,排除!
对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); 通过遇到的这个问题小编我来说说今天的主题:日期向字符串转换,可以设置任意的转换格式format,使任意类型的数据转换成一个字符串。
使用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为其他格式,可考虑重新解析下字符串,再重组~~
使用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(); } 很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式
声明:查API可知,Date和Timesta是父子类关系
Timestamp ts = new Timestamp(System.currentTimeMillis()); Date date = new Date(); try { date = ts; System.out.println(date); } catch (Exception e) { e.printStackTrace(); }
// 会丢失时间数据 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()等等
