MyBatis框架动态查询Sql
时间:2022-07-22
本文章向大家介绍MyBatis框架动态查询Sql,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
今天写一个接口,查询监测数据,传感器有100多个监测因子,也就是数据库中一条数据对应100多个字段,前端勾选需要查询的监测因子,所以接口就需动态查询字段,幸运的是Mybatis支持这种查询
用foreach来循环遍历所需字段: foreach 基本语法:标签体内主要属性有item、index、collection、open、separator、close
item:集合中元素迭代时的别名 index:集合中元素迭代时的索引 open:表示以什么开始 separator:表示在每次进行迭代时的分隔符 close 常用语where语句中,表示以什么结束
select
DATE_FORMAT(rtc_time,'%Y-%m-%d %H:%i:%s') rtcTime,
<foreach collection="factorList" item="factor" open="" separator="," close="">
${factor}
</foreach>
from tb_material_data
前端传什么sql就查询什么,比如params.pollution传No2就查询No2,传的Co就查询Co
SELECT
ws.station_id AS stationId,
ws.station_name AS stationName,
p.${params.pollution} AS pollutionValue,
FROM tb_station ws
LEFT JOIN tb_station_aqi p ON ws.station_id = p.station_id
也可以动态排序
ORDER BY
p.${params.pollution} DESC
升序降序也可以动态
p.${params.pollution} ${params.order}
动态查询有的同学担心容易Sql注入,所以Service层可以做一个参数合法性验证,验证参数是否是合法就好了。如果是合法才调用Mapper层。
- OVN实战二之Overlay实现
- SQLI-LABS 更新帖(一)
- 众测备忘手册
- 我博客上的围棋js程序
- Laravel 开发 RESTful API 的一些心得
- Hive使用十六进制分隔符异常分析
- 智能家居系统结构
- 一个简单的完全信息动态博弈的解答
- Struts2远程代码执行漏洞S2-052 复现&防御方案
- CENTOS6.5安装CDH5.12.1(二)
- @ControllerAdvice + @ExceptionHandler 处理 全部Controller层异常
- 动态增加表单元素并获取元素的text和value提交
- SpringBoot常用配置
- Json格式String类型字符串转为Map工具类
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- python如何支持并发方法详解
- thinkPHP+mysql+ajax实现的仿百度一下即时搜索效果详解
- php和C#的yield迭代器实现方法对比分析
- Python字符串函数strip()原理及用法详解
- python中取绝对值简单方法总结
- Linux中将txt导入到mysql的办法教程
- 深入了解NumPy 高级索引
- CentOS7设置jar应用程序开机启动的办法
- linux系统 java环境变量的配置办法
- 在Linux中怎么轻松删除源安装的软件包
- Linux中selinux基础配置教程详解
- 怎么禁用 Ubuntu 服务器中终端欢迎消息中的广告
- Laravel5.1 框架响应基本用法实例分析
- 在Linux中怎么一次重命名多个文件详解
- python调用私有属性的方法总结