最近遇到一个需求,查询数据库中对应表的字段是动态的,项目使用的框架使用JPA+Spring Boot,JPA自带原生SQL支持的传入参数是强类型的,无法用于查询语句的字段更改,因为插入字符串的话带有单引号,需要另外定义原生SQL

因此我们创建一个查询类

import com.weiqitonggame.trade.model.WebInfo;
import org.springframework.stereotype.Component;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext; @Component //标记为组件,spring启动时会将该类扫描进容器

public class InformationDaoEM {
@PersistenceContext </span><span style="color: #008000;">//</span><span style="color: #008000;">注入的是实体管理器,执行持久化操作</span>

EntityManager entityManager;

</span><span style="color: #0000ff;">public</span><span style="color: #000000;"> String getInfoWebWaring(String column){
String SQL </span>= "SELECT "+column+" FROM config LIMIT 1"<span style="color: #000000;">;
Object obj </span>=<span style="color: #000000;"> entityManager.createNativeQuery(SQL).getSingleResult(); </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> String.valueOf(obj);
} </span><span style="color: #0000ff;">public</span><span style="color: #000000;"> WebInfo getWebInfo(String [] args){ String SQL </span>= "SELECT id, "+<span style="color: #000000;">
args[</span>0]+" log_url, "+<span style="color: #000000;">
args[</span>1]+" title, "+<span style="color: #000000;">
args[</span>2]+" key_word, "+<span style="color: #000000;">
args[</span>3]+" description, "+<span style="color: #000000;">
args[</span>4]+" address, "+<span style="color: #000000;">
args[</span>5]+" contact "+
"FROM config LIMIT 1"<span style="color: #000000;">; WebInfo webInfo </span>= (WebInfo) entityManager.createNativeQuery(SQL,WebInfo.<span style="color: #0000ff;">class</span><span style="color: #000000;">).getSingleResult(); </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> webInfo;
}

}

其中
EntityManager.createNativeQuery(SQL)返回的是Object对象
entityManager.createNativeQuery(SQL,WebInfo.class)返回的是映射后的实例对象
实体类WebInfo需要进行以下处理,确保被扫描进spring容器

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors; import javax.persistence.*; @Data //生成读写方法

@AllArgsConstructor //生成全参构造方法

@NoArgsConstructor //生成无参构造方法

@Accessors(chain = true)

@Entity(name = "tableName") //标记为entity

public class WebInfo {

@Id

@GeneratedValue(strategy= GenerationType.AUTO)

@Column(name = "id") //查询结果对应字段

private Integer id;

@Column(name = "log_url")

private String logUrl;

@Column(name = "title")

private String title;

@Column(name = "key_word")

private String keyWord;

@Column(name = "description")

private String description;

@Column(name = "address")

private String address;

@Column(name = "contact")

private String contact; }

Query.getSingleResult() 执行SQL语句,返回一个查询结果,常用的还有以下方法
Query.getResultList() () 执行SQL语句,返回一个List集合
Query.getFirstResult() () 执行SQL语句,返回一个系列结果集合的第一个

调用方式如下:

import org.springframework.stereotype.Service;
import com.weiqitonggame.trade.service.InformationService;
import org.springframework.beans.factory.annotation.Autowired;
import com.weiqitonggame.trade.dao.InformationDaoEM;
import com.weiqitonggame.trade.model.WebInfo; @Service //标记为service

public class InformationServiceImpl implements InformationService {
@Autowired  </span><span style="color: #008000;">//</span><span style="color: #008000;">注入informationDaoEM</span>
<span style="color: #0000ff;">private</span><span style="color: #000000;"> InformationDaoEM informationDaoEM; @Override
</span><span style="color: #0000ff;">public</span><span style="color: #000000;"> String getWebWaring(String column) { </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> informationDaoEM.getInfoWebWaring(column);
} @Override
</span><span style="color: #0000ff;">public</span><span style="color: #000000;"> WebInfo getWebInfo(String[] args) { </span><span style="color: #0000ff;">return</span><span style="color: #000000;"> informationDaoEM.getWebInfo(args);
}

}

最新文章

  1. Golang汇编命令解读
  2. [Algorithm] 局部敏感哈希算法(Locality Sensitive Hashing)
  3. leveldb 性能、使用场景评估
  4. mybatis报错invalid types () or values ()解决方法
  5. SpringMVC+Mybatis+Spring整合
  6. Hibernate Synchronizer3——一个和hibernate Tool类似的小插件之使用方法
  7. DailyReport自动保存工具
  8. FushionCharts Free 的运用[2D/3D图表处理]
  9. SSIS -&gt;&gt; Script Task
  10. LINQ to XML 从逗号分隔值 (CSV) 文件生成 XML 文件
  11. 枚举类:用enum关键字来定义一个枚举类
  12. TLSAlloc()
  13. Spring Security @PreAuthorize 拦截无效
  14. [wiki]CDN
  15. 从零开始学习前端JAVASCRIPT — 2、JavaScript基础ES5
  16. 算法(第四版)C# 习题题解——3.1
  17. SharePoint 2013 新特性 (三) 破改式 &mdash;&mdash; 设计管理器的使用 [2.HTML变身模板页]
  18. Unity 读写文本 文件
  19. Excel导入工具类兼容xls和xlsx
  20. 6条 Tips 为你照亮 GitHub 寻宝之路

热门文章

  1. React.js 的 context
  2. (一)Mybatis之初步接触
  3. asp.net 中文部分显示问号
  4. systemtap执行过程中报probe timer.profile registration error
  5. Python 风格规范
  6. Apache安装和文件配置
  7. C-基础:memcpy、memset、memmove、memcmp、memchr
  8. MySQL-02 数据表管理
  9. github下拉刷新与上拉加载地址
  10. Java编程:常见问题汇总