Hibernate用得久了,但是一些基础知识却不知不觉忘记了,这不,今天就遇到了一个有趣的异常,搞了半小时才让我发现原因,郁闷啊。
异常信息:Exception in thread "main" org.hibernate.TypeMismatchException: Provided id of the wrong type. Expected: class java.lang.Integer, got class java.lang.String
一开始我以为id属性在配置文件的类型配置不正确,仔细检查一遍并没有发现什么不对,实体类里用的Integer类型,oracle数据库里用的是number类型,怎么可能查出来的数据的id这列是String型呢,百思不得其解,没办法,只能一句一句的找,看哪句代码可能出问题,最后终于找到了嫌疑代码,修改后证实确实是这句出了问题,代码如下:
Student gets=(Student)session.get(Student.class, "100");
取数据是,我给的id是字符串 "100" 所以查出来的数据也自动将这一列也自动给转成了String型。 真是无语! 谁让我没事给后面的id参数加个双引号呢, 无奈, Hibernate真是太智能了, 看来基础知识还是很重要啊, 希望各位不要再犯我的这种错误, 在学习新技术的同时要温习一些基础知识,别搞个大工程,结果50%的时间浪费在了无谓的小错误上 。 这里顺便把Hibernate的测试代码贴出来,给大家温习一下。没事做做小测试,温习一下也好:
public static void main(String[] args) {
//最开始我们要创建需要使用Hibernate保存到数据库中的对象
Student s = new Student();
s.setAge(20);
s.setName("kj");
s.setClassName("t101");
//然后是使用Hibernate操作数据库的过程
//首先创建Configuration对象
Configuration configuration = new Configuration();
configuration.configure();
//然后使用配置对象configuration创建SessionFactory对象
SessionFactory sessionFactory = configuration.buildSessionFactory();
//使用sessionFactory创建Session对象
Session session = sessionFactory.getCurrentSession();
//然后使用session开始一个事务
Transaction tx = session.beginTransaction();
//使用session保存对象到数据库
//session.save(s);
//使用session查询数据库中的数据
Student gets=(Student)session.get(Student.class, "100");
System.out.println(gets.toString());
//提交事务,对象数据真正保存到数据库中
tx.commit();
}