Hibernate org.hibernate.TypeMismatchException异常

    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();

 

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值