EntityManager获取connection进行jdbc操作

鉴于hibernate一些查询的局限性,这次就碰到一不支持as别名、二来因需要连表查询select t1.id和t5.id,log上打印的sql语句在navicat中执行数据都是对的两个不同的id,但在查询出来的Object[]数组中获取的两个字段值是一样的。这就尴尬了。
根据使用的jar版本不同获取的方式会有差异,用em的unwrap()方法会报nusuchmethod异常。
EntityManager em = this.getJpaTemplate().getEntityManagerFactory()
			.createEntityManager();
Session session = (org.hibernate.Session) em.getDelegate();
SessionFactoryImplementor sf=(SessionFactoryImplementor)session.getSessionFacory(); 
Connection connection =sf.getConnectionProvider().getConnection();
*之后使用的方式就是最基础的jdbc操作了,记得在try-catch代码块中写,最后在finally中关闭connection、preparedstatement、resultset。	

转载于:https://my.oschina.net/u/2405670/blog/701312

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值