springboot+mybatis环境的坑和sql语句简化技巧
1.springfox-swagger实体类无限递归
https://hacpai.com/article/1525674135818 里面有不完美的解决方案
不用动源码的解决方案也有,在swagger项目里的函数传入参数没有类互相包含就可以了
这也要求某些多对多关系的实体类的属性定义要仔细走关系图
比如User和SysClass,用在swagger传入参数的实体类不能互相包含List<SysClass>和List<User>
只能继承VO(这个VO不能作为swagger函数的传入参数),把对应的包含属性写进去,然后需要查询对应列表时返回VO就行了
2.有中间表的mybatis一对多查询
查看某些有明确一对多关系的实体类的mybatis xml,可以看到查询方式是主表join子表,然后在mybatis这端把主表的数据group起来作为某个对象的元素
由此可见没有直接关联的2个表对应的类也可以用这种方式查询
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.ass.core.mapper.SysClassMapper"> <!-- 可根据自己的需求,是否要使用 -->
<resultMap type="com.ass.core.entity.SysClass" id="classMap">
<result property="id" column="cid"/>
<result property="code" column="code"/>
<result property="name" column="name"/>
<result property="num" column="num"/>
<result property="description" column="description"/>
</resultMap>
<resultMap type="com.ass.core.VO.ClassWithUser" id="classUser">
<result property="id" column="cid"/>
<result property="code" column="code"/>
<result property="name" column="name"/>
<result property="num" column="num"/>
<result property="description" column="description"/>
<collection property="teachers" ofType="User">
<id column="id" jdbcType="INTEGER" property="id" />
<result column="uid" jdbcType="VARCHAR" property="uid" />
<result column="user_account" jdbcType="VARCHAR" property="userAccount" />
<result column="password" jdbcType="VARCHAR" property="password" />
<result column="username" jdbcType="VARCHAR" property="username" />
<result column="user_identity" jdbcType="INTEGER" property="userIdentity" />
<result column="user_status" jdbcType="INTEGER" property="userStatus" />
<result column="user_type" jdbcType="INTEGER" property="userType" />
<result column="user_email" jdbcType="VARCHAR" property="userEmail" />
<result column="user_mobile" jdbcType="VARCHAR" property="userMobile" />
<result column="user_remind" jdbcType="VARCHAR" property="userRemind" />
<result column="user_create_time" jdbcType="TIMESTAMP" property="userCreateTime" />
<result column="user_update_time" jdbcType="TIMESTAMP" property="userUpdateTime" />
<result column="class_id" jdbcType="VARCHAR" property="classId" />
<result column="user_col2" jdbcType="VARCHAR" property="userCol2" />
<result column="user_col3" jdbcType="VARCHAR" property="userCol3" />
<result column="user_token" jdbcType="VARCHAR" property="userToken" />
<result column="role_id" jdbcType="VARCHAR" property="roleId" />
</collection>
</resultMap> <select id="selectClassListByName" resultMap="classUser">
SELECT
c.id as cid,
c.code,
c.name,
c.num,
c.description,
u.*
FROM
sys_class c
LEFT JOIN user_class uc ON c.id = uc.class_id
LEFT JOIN user u ON u.uid = uc.user_id
WHERE
c.name like '%${name}%'
</select> </mapper>
SysClassMapper.xml
3.swagger传入参数含有对象数组时的坑点
swagger前端在碰到对象数组(无论是直接传的还是实体类里面的)时,会显示xxx[0].id和xxx[0].name之类的参数,但是直接通过前端发送请求,会因为url含有非法字符被拒绝请求
如果是用其他程序提交,例如Python(先安装requests扩展包),可以提交这种带对象数组的请求,并让服务器接收
import requests
import json def login():
res = requests.post('http://localhost:20005/api/user/login?userAccount=admin&userPassword=admin', verify=False)
myj = json.loads(res.text)
#print(myj)
return myj['data']['token']
#
def addContent():
token = login()
params = {
'resourceSteps[0].procedureName': 'ytmym',
'resourceSteps[0].procedureContent': 'mytm',
'resourceSteps[2].procedureName': 'loveZJJ',
'resourceSteps[2].procedureContent': 'asswecan',
'id': '',
'resourceContentId': '45j45j',
'experimentAdd': '5j5j',
'experimentAdd1': 'grh',
'stepsjson': '[{"procedureName":"a","procedureContent":"b"}]',
'token': token,
'resourceManagementId': 'j54j45j',
'experimentalObjective': '45j45j4',
'experimentalContext': '45j45j',
'experimentalRequirements': '5j45j',
'prepareKnowledge': '54j45j',
'experimentSummary': 'j54j',
'experimentTestId': 'h4h54'
}
url = 'http://localhost:20005/api/resource/add/content'
res = requests.post(url, params=params)
print(res.text)
#
if __name__ == '__main__':
addContent()
但是这种实现方式不太推荐,太不直观了。建议使用@ResponseBody注解对象数组或包含此类型的实体类,然后让前端传入json,处理会简单一些
springboot+mybatis环境的坑和sql语句简化技巧的更多相关文章
- springBoot + mybatis实现执行多条sql语句出错解决方法
在Idea中执行多条sql语句的修改(mybatis默认的是执行sql语句是执行单条,所以要执行多条的时候需要进行配置) 需要在连接字符串中添加上&allowMultiQueries=true ...
- MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存
目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...
- MyBatis学习 之 二、SQL语句映射文件(1)resultMap
目录(?)[-] 二SQL语句映射文件1resultMap resultMap idresult constructor association联合 使用select实现联合 使用resultMap实 ...
- mybatis 控制台打印执行的SQL语句
1. Spring boot 集成 mybatis [转载]SpringBoot中Mybatis打印sql 1.1 如果使用的是application.properties文件,加入如下配置: log ...
- MyBatis学习总结_11_MyBatis动态Sql语句
MyBatis中对数据库的操作,有时要带一些条件,因此动态SQL语句非常有必要,下面就主要来讲讲几个常用的动态SQL语句的语法 MyBatis中用于实现动态SQL的元素主要有: if choose(w ...
- MyBatis 入门到精通(二) SQL语句映射XML文件
MyBatis 真正强大之处就在这些映射语句,也就是它的魔力所在.对于它的强大功能,SQL 映射文件的配置却非常简单. 如果您比较SQL 映射文件配置与JDBC 代码,您很快可以发现,使用SQL 映射 ...
- mybatis基础学习1---(配置文件和sql语句)
1:配置文件(主要配置文件) 2:配置文件(引入) 3:sql语句解析: <mapper namespace="/"> <!-- 1 -->根据id查对象 ...
- MyBatis 源码分析——动态SQL语句
有几年开发经验的程序员应该都有暗骂过原生的SQL语句吧.因为他们不能一句就搞定一个业务,往往还要通过代码来拼接相关的SQL语句.相信大家会理解SQL里面的永真(1=1),永假(1=2)的意义吧.所以m ...
- mybatis下使用log4j打印sql语句和执行结果
转载自:https://www.cnblogs.com/jeevan/p/3493972.html 本来以为很简单的问题, 结果自己搞了半天还是不行; 然后google, baidu, 搜出来各种方法 ...
随机推荐
- C语言面试题分类->宏定义
1.写一个“标准”宏,这个宏输入两个参数并返回较小的一个 答:#define MIN(x, y) ((x)<(y)?(x):(y))//注意x,y要加括号,因为x,y如果有复合运算会出现问题. ...
- dhtmlx Gantt实例介绍分析
API地址:https://docs.dhtmlx.com/gantt/desktop__guides.html,这是英文的网页,可以用谷歌打开然后页面翻译,就是中文的啦! 我用的是DHTMLX Ga ...
- canvas动态修改宽高问题
Canvas元素默认宽 300px, 高 150px, 设置其宽高可以使用如下方法:方法一:1 <canvas width="500" height="500&qu ...
- 通过使用Web Workers,Web应用程序可以在独立于主线程的后台线程中,运行一个脚本操作。这样做的好处是可以在独立线程中执行费时的处理任务,从而允许主线程(通常是UI线程)不会因此被阻塞/放慢。
Web Workers API - Web API 接口参考 | MDNhttps://developer.mozilla.org/zh-CN/docs/Web/API/Web_Workers_API ...
- ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key
约束字段为自动增长,被约束的字段必须同时被key约束 没有设置成primary key 时,会报错. 加上primary key 则设置成功.
- AIROBOT系统 之 踏浪而来
缘由 为什么要做AIROBOT?其实自从我知道智能家居这个领域之后,就一直想打造一个自己的智能家居控制平台,算是我的一个梦.最开始的项目还是在安居客当时工作的时候做的,项目地址:https://git ...
- git 和github使用
强制推送覆盖到远程仓库!!
- Python_对Excel表进行操作
1.使用Python统计Excel表中的行数 import xlrd # 计算一个工作簿中所有Sheet表的行数 def count_book(work_book): workbook = xlrd. ...
- 找出sql脚本中需要创建的表空间名称和数据库用户名
测试的工作中,经常会遇到项目交接或者搭建一个新的测试环境,而创建oracle数据库用户及表空间时,需要提前找出脚本中的 数据库用户名和表空间名,所以自己写了一个python脚本,自动找出sql脚本中的 ...
- 有几个PAT
描述 字符串APPAPT中包含了两个单词“PAT”,其中第一个PAT是第2位(P),第4位(A),第6位(T):第二个PAT是第3位(P),第4位(A),第6位(T). 现给定字符串,问一共可以形成多 ...