JPA EntityManager查询--使用原生sql查询
SQL查询多个字段
query.getResultList() 返回List类型,每个对象类型是Obejct类型的数组。List<Object[]>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | import java.math.BigDecimal; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.PersistenceContext; import javax.persistence.Query; public class JpaDemoTest { @PersistenceContext private EntityManager em; public void testJpaNativeQuery() { BigDecimal classNo = null ; BigDecimal studentNo = null ; String remark = null ; String sql = "select t.class_no ,t.student_no ,t.remark from t_student t where t.class_no =:class_no " ; Query query = em.createNativeQuery(sql); query.setParameter( "class_no" , 20 ); //返回Object[] 类型的List List objecArraytList = query.getResultList(); for ( int i = 0 ; i < objecArraytList.size(); i++) { //每个结果是Obect[] 类型 Object[] obj = (Object[]) objecArraytList.get(i); classNo = (BigDecimal) obj[ 0 ]; studentNo = (BigDecimal) obj[ 1 ]; remark = (String) obj[ 2 ]; } System.out.println( "classNo==" + classNo + ";studentNo==" + studentNo + ";remark==" + remark); } } |
SQL查询一个字段
query.getResultList() 返回List类型,每个对象类型是Obejct。List<Object>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | import java.math.BigDecimal; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.PersistenceContext; import javax.persistence.Query; public class JpaDemoTest { @PersistenceContext private EntityManager em; public void testJpaNativeQuery() { BigDecimal classNo = null ; String sql = "select t.class_no from t_student t where t.class_no =:class_no " ; Query query = em.createNativeQuery(sql); query.setParameter( "class_no" , 20 ); //返回Object 类型的List List objecArraytList = query.getResultList(); for ( int i = 0 ; i < objecArraytList.size(); i++) { //每个结果是Obect类型 classNo = (BigDecimal) objecArraytList.get(i); } System.out.println( "classNo==" + classNo ); } } |
分类:
JPA
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY