【Mybatis】Bonus02 补充
关于主键生成问题
Mybatis的主键生成是基于JDBC的使用主键【getGeneratedKeys()】方法
也就是说,必须要JDBC驱动的支持才行
@Test
public void junitTest() throws SQLException {
Connection connectionByOriginalJdbc = CompleteJdbcUtils.getConnectionByOriginalJdbc();、
PreparedStatement preparedStatement = connectionByOriginalJdbc.prepareStatement("");
ResultSet generatedKeys = preparedStatement.getGeneratedKeys();
}

useGeneratedKeys 表示使用数据库生成的主键,
keyProperty 表示绑定数据表的主键返回给实体类的哪个字段

在之前的插入SQL中并不需要主键生成功能就能完成主键自增生成,
看来是JDBC自动生成的【如果开启就像官方说的一样,是强制生成的】
实现主键生成的第二种方式:
使用<SelectKey> 标签
SELECT last_insert_id 表示查询最后一次插入的id
如果在SQL执行前查询,就返回最后一次插入的记录的id
然后我们的插入SQL就会按这个查询的id插入,这样插入是有问题的,
所以要选择AFTER,在执行插入后返回主键,再生成

对应的,使用注解实现的方式

关于getMapper底层实现原理
这是一个查询的SQL
先获取会话实例
然后从会话中获取Mapper实现类
调用查询SQL,完成后释放资源

通过调试查看源码
其实也是使用动态代理完成的

根据command的类型来处理,
一共四个Case,也正好就是我们Mapper的4个SQL标签
而在增删改3个,都是直接注入SQL即可,因为返回只有修改的记录结果数

SELECT反而更为复杂
需要根据查询的结果要求进行处理

摘要自: https://www.bilibili.com/video/BV1dV411o7bA?p=11
关于参数占位符
在多个普通参数注入的情况,我们可以使用这种占位符表示,
也就是不通过名称标识注入

如果是多个实体类类型的参数。。。

关于驼峰命名匹配
Java实体类声明的映射字段是以驼峰命名的,
例如:
userId,userName,userPassword
但是数据库的字段是不区分大小写的,尤其是Oracle数据库,会直接全大写
一般设置的字段会是这样,
例如:
user_id,user_name,user_password
或者Oracle全大写的这样
USER_ID,USER_NAME,USER_PASSWORD
Mybatis的设置项中可以开启一个驼峰命名映射,帮助这个字段进行匹配
<settings>
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
如果你打算完全一致的声明ORM字段列表示,请不要设置驼峰匹配!!!
这会导致Mybatis无法找到数据表的字段【显示一切正常】

你会根本找不到什么问题,所有配置完全一致,结果就是返回null
关于模糊查询Like 更好的安全写法

【Mybatis】Bonus02 补充的更多相关文章
- Spring Boot 知识笔记(整合Mybatis续-补充增删改查)
续上篇,补充数据库增删改查的其他场景. 一.Mapper中添加其他场景操作 package net.Eleven.demo.Mapper; import net.Eleven.demo.domain. ...
- 深入浅出Mybatis系列(二)---Mybatis入门
一.Mybatis环境搭建及简单实例 1. 新建web项目, 添加依赖包:mybatis包.数据库驱动包(我使用的是mysql).日志包(我使用的是log4j), 由于我的是maven项目, 那么添加 ...
- 【Java资源免费分享,网盘自己拿】
JavaSE: Java马士兵:链接:https://pan.baidu.com/s/1jJRvxGi密码:v3xb Java毕向东:链接:https://pan.baidu.com/s/1ggzHk ...
- JAVA视频链接
Java基础Java马士兵:链接:https://pan.baidu.com/s/1jJRvxGi密码:v3xb Java刘意:链接:https://pan.baidu.com/s/1kVZQCqr密 ...
- Java视频教程免费分享(网盘直接取)
Java基础 Java马士兵:链接:https://pan.baidu.com/s/1jJRvxGi密码:v3xb Java刘意:链接:https://pan.baidu.com/s/1kVZQCqr ...
- Spring框架第一天(搭建项目)
Spring框架 1.简介 1.1 Spring是什么 一个开源的框架,是JavaEE开源框架 Spring是分层的 Java SE/EE应用 full-stack 轻量级开源框架,以IoC(Inve ...
- MyBatis数据库连接的基本使用-补充Mapper映射器
补充 Mapper映射器的使用: Mapper映射器,google添加.Mapper映射器是将mapper.xml中配置的sql id,parameterType和resultMap按照规则一一映射到 ...
- MyBatis数据库连接的基本使用-补充
补充1 MyBatis使用过程中,返回值类型可能是Map,不一定是实体类 返回查询结果也可以是一个Map,不一定是实体类 (1)mybatis会先将查询结果返回为一个map,字段名作为key,字段值 ...
- Mybatis源码学习第六天(核心流程分析)之Executor分析(补充)
补充上一章没有讲解的三个Executor执行器; 还是贴一下之前的代码吧;我发现其实有些分析注释还是写在代码里面比较好,方便大家理解,之前是我的疏忽,不好意思 @Override public < ...
- MyBatis的关联关系补充 多对多 继承
多对多 一个学生有多个课程 一个课程有多个学生 思路分析 :使用一个中间表 用学生表和课程表的主键作为中间表的联合主键 1数据库表的设计 课程表 学生表 中间表 2/实体类的设计 课程类 public ...
随机推荐
- C# .NET Dictionary 将集合key以ascii码从小到大排序
.NET 不加参数,默认不是按ASC II 排序 .JAVA 默认是按ASC II 排序 . Array.Sort(arrKeys, string.CompareOrdinal); 按ASC II 排 ...
- Python基础——上节补充及数据类型
1.变量的创建过程 当我们创建一个变量name='oldboy'时,实际上是这样一个过程. 程序先开辟了一个内存空间,把变量的内容放进去,再让变量name指向'oldboy'所在的内存地址. 我们可以 ...
- http请求方式-CloseableHttpClient
http请求方式-CloseableHttpClient import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObjec ...
- fastadmin的导出到excel功能
正常的excel导出没什么问题,最近一直头疼的是怎么导出数据中包含图片,并且图片还是数组?????by user 悦悦 https://www.cnblogs.com/nuanai 1.导出的exce ...
- Spring之WebMvcConfigurationSupport
WebMvcConfigurationSupport是mvc的核心配置.开发spring,了解和掌握这个是必须的. 为了简约篇幅,本文把"WebMvcConfigurationSupport ...
- Java面试知识点(三)Java中的单继承和多继承
多继承的优缺点 优点:对象可以调用多个父类中的方法 缺点:如果派生类所继承的多个父类有相同的父类(也就是一个菱形继承结构),而派生类对象需要调用这个祖先类的方法,就会容易出现二义性. 1.java 与 ...
- BST-Treap名次树指针实现板子 Ver2.1
为了更好的阅读体验,请点击这里 这里只有板子没有原理QWQ 可实现 1.插入 x 数 2.删除 x 数(若有多个相同的数,只删除一个) 3.查询 x 数的排名(排名定义为比当前数小的数的个数 +1) ...
- .NET 高效灵活的API速率限制解决方案
前言 FireflySoft.RateLimit是基于.NET Core和.NET Standard构建,支持多种速率限制算法和策略,包括固定窗口.滑动窗口.漏桶.令牌桶等.通过简单的配置和集成,开发 ...
- CLR via C# 笔记 -- 异常和状态管理(20)
1. 异常是指成员没有完成它的名称所宣称的行动,异常类继承System.Exception. 2. .Net Framework 异常处理机制是用Microsoft windows提供的结构化异常处理 ...
- 配置h5py、netCDF4库的方法:Anaconda环境
本文介绍基于Anaconda环境,下载并安装Python中h5py与netCDF4这两个模块的方法. 在Python语言中,h5py与netCDF4这两个模块是与遥感图像处理.地学分析等GIS ...