JPA 原生态SQL 的复杂查询之createNamedQuery调用存储过程,返回的List字段对应的填充实体
============实体类,调用存储过程==========================
@NamedNativeQueries({  
    @NamedNativeQuery(  
        name = "getNativeNutShellInfo",   //需要调用的name
        query = "{call cp_syslogin_web(?,?,?)}",   //存储过程,返回的List字段对应的值@EntityResult此处填充实体的属性值
        resultSetMapping = "ReturnColumnEntityList" 
    )  
})  
 
@SqlResultSetMappings({  
    @SqlResultSetMapping(  
        name = "ReturnColumnEntityList",  
        entities = {
          @EntityResult(entityClass = NutShellInfo.class,fields={  //返回的List字段对应的值此处填充实体的属性值
           @FieldResult(name = "aguid", column = "aguid"),
           @FieldResult(name = "user", column = "htkusr"),
           @FieldResult(name = "qty", column = "qtynow"),
           @FieldResult(name = "registered", column = "breg"),
           @FieldResult(name = "hint", column = "hint"),
           @FieldResult(name = "ver", column = "ver"),
           @FieldResult(name = "overQty", column = "boverqty"),
           @FieldResult(name = "timeout", column = "btimeout"),
           @FieldResult(name = "host", column = "htkwww")
          })

}

)  
})

@Entity
public class NutShellInfo {
 @Id
 private String aguid;
 @Column(name = "htkusr")
 private String user;
 @Column(name = "qtynow")
 private double qty;
 @Column(name = "breg")
 private boolean registered;
 private String hint;
 private String ver;
 @Column(name = "boverqty")
 private boolean overQty;
 @Column(name = "btimeout")
 private boolean timeout;
 @Column(name = "htkwww")
 private String host;
 @Transient
 private String password;//这个字段不对数据库操作

public String getUser() {
  return user;
 }

public void setUser(String user) {
  this.user = user;
 }

public double getQty() {
  return qty;
 }

public void setQty(double qty) {
  this.qty = qty;
 }

public boolean isRegistered() {
  return registered;
 }

public void setRegistered(boolean registered) {
  this.registered = registered;
 }

public String getHint() {
  return hint;
 }

public void setHint(String hint) {
  this.hint = hint;
 }

public String getVer() {
  return ver;
 }

public void setVer(String ver) {
  this.ver = ver;
 }

public boolean isOverQty() {
  return overQty;
 }

public void setOverQty(boolean overQty) {
  this.overQty = overQty;
 }

public boolean isTimeout() {
  return timeout;
 }

public void setTimeout(boolean timeout) {
  this.timeout = timeout;
 }

public String getHost() {
  return host;
 }

public void setHost(String host) {
  this.host = host;
 }

public String getPassword() {
  return password;
 }

public void setPassword(String password) {
  this.password = password;
 }

=========================dao=========================
 @Service
 public class PubBaseDaoImpl<T> implements PubBaseDao<T> {
 private EntityManager em = null;

@PersistenceContext
 public void setEm(EntityManager em) {
  this.em = em;
 }

@Override
 public List<T> qryNamedQuery(String nativeName,Object[] params) {
  Query q = em.createNamedQuery(nativeName);
  setQueryParams(q, params);
  return q.getResultList();
 }

public void setQueryParams(Query query, Object[] params) {
  try {
   if (params != null && params.length > 0) {
    for (int i = 0; i < params.length; i++) {
     query.setParameter(i + 1, params[i]);
    }
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

=================services===================================
 @Override
 public void qryInfo(String userId, String machineCode) {
  List<NutShellInfo> list = baseDao.qryNamedQuery("getNativeNutShellInfo",new Object[] { userId, machineCode, 0 });
  
 }

JPA 原生态SQL 的复杂查询之createNamedQuery,select * from查询,返回的List字段对应的填充实体
============实体类==========================
@NamedNativeQueries({  
    @NamedNativeQuery(  
        name = "getNativeNutShellInfo",   //需要调用的name
        query = "select * from NutShellInfo where aguid=? and  htkusr=? and btimeout=? ",   //存储过程,返回的List字段对应的值@EntityResult此处填充实体的属性值
        resultSetMapping = "ReturnColumnEntityList" 
    )  
})  
 
@SqlResultSetMappings({  
    @SqlResultSetMapping(  
        name = "ReturnColumnEntityList",  
        entities = {
          @EntityResult(entityClass = NutShellInfo.class,fields={  //返回的List字段对应的值此处填充实体的属性值
           @FieldResult(name = "aguid", column = "id"),
           @FieldResult(name = "user", column = "htkusr"),
           @FieldResult(name = "qty", column = "qtynow"),
           @FieldResult(name = "registered", column = "breg"),
           @FieldResult(name = "hint", column = "hint"),
           @FieldResult(name = "ver", column = "ver"),
           @FieldResult(name = "overQty", column = "boverqty"),
           @FieldResult(name = "timeout", column = "btimeout"),
           @FieldResult(name = "host", column = "htkwww")
          })

}

)  
})

@Entity
public class NutShellInfo {
 @Id
 private String aguid;
 @Column(name = "htkusr")
 private String user;
 @Column(name = "qtynow")
 private double qty;
 @Column(name = "breg")
 private boolean registered;
 private String hint;
 private String ver;
 @Column(name = "boverqty")
 private boolean overQty;
 @Column(name = "btimeout")
 private boolean timeout;
 @Column(name = "htkwww")
 private String host;
 @Transient
 private String password;//这个字段不对数据库操作

public String getUser() {
  return user;
 }

public void setUser(String user) {
  this.user = user;
 }

public double getQty() {
  return qty;
 }

public void setQty(double qty) {
  this.qty = qty;
 }

public boolean isRegistered() {
  return registered;
 }

public void setRegistered(boolean registered) {
  this.registered = registered;
 }

public String getHint() {
  return hint;
 }

public void setHint(String hint) {
  this.hint = hint;
 }

public String getVer() {
  return ver;
 }

public void setVer(String ver) {
  this.ver = ver;
 }

public boolean isOverQty() {
  return overQty;
 }

public void setOverQty(boolean overQty) {
  this.overQty = overQty;
 }

public boolean isTimeout() {
  return timeout;
 }

public void setTimeout(boolean timeout) {
  this.timeout = timeout;
 }

public String getHost() {
  return host;
 }

public void setHost(String host) {
  this.host = host;
 }

public String getPassword() {
  return password;
 }

public void setPassword(String password) {
  this.password = password;
 }

=========================dao=========================
 @Service
 public class PubBaseDaoImpl<T> implements PubBaseDao<T> {
 private EntityManager em = null;

@PersistenceContext
 public void setEm(EntityManager em) {
  this.em = em;
 }

@Override
 public List<T> qryNamedQuery(String nativeName,Object[] params) {
  Query q = em.createNamedQuery(nativeName);
  setQueryParams(q, params);
  return q.getResultList();
 }

public void setQueryParams(Query query, Object[] params) {
  try {
   if (params != null && params.length > 0) {
    for (int i = 0; i < params.length; i++) {
     query.setParameter(i + 1, params[i]);
    }
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

=================services===================================
 @Override
 public void qryInfo(String userId, String machineCode) {
  List<NutShellInfo> list = baseDao.qryNamedQuery("getNativeNutShellInfo",new Object[] { userId, machineCode, 0 });
  
 }

JPA 原生态SQL 的复杂查询之createNamedQuery,select xxx,xxx from查询,返回的List字段对应的填充实体
============实体类==========================
@NamedNativeQueries({  
    @NamedNativeQuery(  
        name = "getNativeNutShellInfo",   //需要调用的name
        query = "select aguid,htkusr from NutShellInfo where aguid=? and  htkusr=? and btimeout=? ",   //存储过程,返回的List字段对应的值@EntityResult此处填充实体的属性值
        resultSetMapping = "ReturnColumnEntityList" 
    )  
})  
 
@SqlResultSetMappings({  
    @SqlResultSetMapping(  
        name = "ReturnColumnEntityList",  
        entities = {}
        columns = {
     @ColumnResult(name = "aguid"),  
            @ColumnResult(name = "htkusr"),  
        }
    )  
})

@Entity
public class NutShellInfo {
 @Id
 private String aguid;
 @Column(name = "htkusr")
 private String user;
 @Column(name = "qtynow")
 private double qty;
 @Column(name = "breg")
 private boolean registered;
 private String hint;
 private String ver;
 @Column(name = "boverqty")
 private boolean overQty;
 @Column(name = "btimeout")
 private boolean timeout;
 @Column(name = "htkwww")
 private String host;
 @Transient
 private String password;//这个字段不对数据库操作

public String getUser() {
  return user;
 }

public void setUser(String user) {
  this.user = user;
 }

public double getQty() {
  return qty;
 }

public void setQty(double qty) {
  this.qty = qty;
 }

public boolean isRegistered() {
  return registered;
 }

public void setRegistered(boolean registered) {
  this.registered = registered;
 }

public String getHint() {
  return hint;
 }

public void setHint(String hint) {
  this.hint = hint;
 }

public String getVer() {
  return ver;
 }

public void setVer(String ver) {
  this.ver = ver;
 }

public boolean isOverQty() {
  return overQty;
 }

public void setOverQty(boolean overQty) {
  this.overQty = overQty;
 }

public boolean isTimeout() {
  return timeout;
 }

public void setTimeout(boolean timeout) {
  this.timeout = timeout;
 }

public String getHost() {
  return host;
 }

public void setHost(String host) {
  this.host = host;
 }

public String getPassword() {
  return password;
 }

public void setPassword(String password) {
  this.password = password;
 }

=========================dao=========================
 @Service
 public class PubBaseDaoImpl<T> implements PubBaseDao<T> {
 private EntityManager em = null;

@PersistenceContext
 public void setEm(EntityManager em) {
  this.em = em;
 }

@Override
 public List<T> qryNamedQuery(String nativeName,Object[] params) {
  Query q = em.createNamedQuery(nativeName);
  setQueryParams(q, params);
  return q.getResultList();
 }

public void setQueryParams(Query query, Object[] params) {
  try {
   if (params != null && params.length > 0) {
    for (int i = 0; i < params.length; i++) {
     query.setParameter(i + 1, params[i]);
    }
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

=================services===================================
 @Override
 public void qryInfo(String userId, String machineCode) {
  List<NutShellInfo> list = baseDao.qryNamedQuery("getNativeNutShellInfo",new Object[] { userId, machineCode, 0 });
  
 }

JPA 原生态SQL 的复杂查询之createNamedQuery的更多相关文章

  1. JPA SQL 的复杂查询createNamedQuery

    @NamedNativeQueries({ @NamedNativeQuery( name = "getNativeNutShellInfo", //需要调用的name query ...

  2. SpringData JPA使用JPQL的方式查询和使用SQL语句查询

    使用Spring Data JPA提供的查询方法已经可以解决大部分的应用场景,但是对于某些业务来说,我们还需要灵活的构造查询条件, 这时就可以使用@Query注解,结合JPQL的语句方式完成查询 持久 ...

  3. 基于Spring Boot,使用JPA调用Sql Server数据库的存储过程并返回记录集合

    在上一篇<基于Spring Boot,使用JPA操作Sql Server数据库完成CRUD>中完成了使用JPA对实体数据的CRUD操作. 那么,有些情况,会把一些查询语句写在存储过程中,由 ...

  4. 基于Spring Boot,使用JPA操作Sql Server数据库完成CRUD

    完成一个RESTful服务,提供几个访问接口,用来操作较简单的联系人信息,数据保存在Sql Server数据库中. 1.使用STS创建工程. 使用STS创建RESTful工程,可以参考: <用S ...

  5. JPA的多表复杂查询

    转 JPA的多表复杂查询:详细篇 原文链接: https://mp.weixin.qq.com/s/7J6ANppuiZJccIVN-h0T3Q 2017-11-10 从小爱喝AD钙  最近工作中由于 ...

  6. SpringBoot中使用Spring Data Jpa 实现简单的动态查询的两种方法

    软件152 尹以操 首先谢谢大佬的简书文章:http://www.jianshu.com/p/45ad65690e33# 这篇文章中讲的是spring中使用spring data jpa,使用了xml ...

  7. Sql Server中查询今天、昨天、本周、上周、本月、上月数据

    Sql Server中查询今天.昨天.本周.上周.本月.上月数据 在做Sql Server开发的时候有时需要获取表中今天.昨天.本周.上周.本月.上月等数据,这时候就需要使用DATEDIFF()函数及 ...

  8. sql跨库查询

    ---------------------------------------------------------------------------------- --1. 创建链接服务器 --1. ...

  9. SQL 数据分页查询

    最近学习了一下SQL的分页查询,总结了以下几种方法. 首先建立了一个表,随意插入的一些测试数据,表结构和数据如下图: 现在假设我们要做的是每页5条数据,而现在我们要取第三页的数据.(数据太少,就每页5 ...

随机推荐

  1. 【同行说技术】Android图片处理技术资料汇总(一)

    对于Android开发的童鞋们来说,图片处理时或多或少都会遇到令人头疼和不满意的问题,今天小编收集了5篇Android图片处理的干货文章,一起来看看吧! 一.Android 高清加载巨图方案 拒绝压缩 ...

  2. java注解Annotation

    扯扯注解的蛋 为什么学习注解?学习注解有什么好处?学完能做什么? 1.能够读懂别人的代码,特别是框架相关的代码 2.让编程更加简洁,代码更加清晰 3.让别人高看你一眼 注解是java1.5引入的 概念 ...

  3. 【C#学习笔记】数组使用

    using System; namespace ConsoleApplication { class Program { static void Main(string[] args) { //int ...

  4. yaf框架流程四

    在前面的章节,在bootstrap里添加了一个benchmark插件,简单介绍下yaf的插件机制:http://yaf.laruence.com/manual/yaf.plugin.html Yaf定 ...

  5. Mybatis学习——传递Map型参数

    Spring整合Mybatis调用 public boolean editItemSales(int i_id, int i_sales) { Map<String, Object> ma ...

  6. Linux/Unix shell 监控Oracle监听器(monitor listener)

    使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等.本文给出Linu ...

  7. 抛弃EF,20分构建一个属于自己的ORM框架

    Poiuyt_cyc 博客园首页新随笔联系订阅管理随笔 - 11  文章 - 0  评论 - 111 抛弃EF,20分构建一个属于自己的ORM框架 相信EF大家都不陌生了,因为数据库表跟程序实体是一一 ...

  8. crontab的安装及crontab命令介绍

    前一天学习了 at 命令是针对仅运行一次的任务,循环运行的例行性计划任务,linux系统则是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因此这个 ...

  9. Nginx - Windows下Nginx基本安装和配置

    Nginx 是一个轻量级的高性能 Http WebServer,以事件驱动方式编写,因此相比 Apache 而言,Nginx 更加稳定.性能更好,而且配置简单,资源占用较低. 1. 安装 Nginx ...

  10. Selenium2Library系列 keywords 之 _ElementKeywords

    #公有方法: (1)current_frame_contains(self, text, loglevel='INFO') (2)current_frame_should_not_contain(se ...