关于主键生成问题

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 补充的更多相关文章

  1. Spring Boot 知识笔记(整合Mybatis续-补充增删改查)

    续上篇,补充数据库增删改查的其他场景. 一.Mapper中添加其他场景操作 package net.Eleven.demo.Mapper; import net.Eleven.demo.domain. ...

  2. 深入浅出Mybatis系列(二)---Mybatis入门

    一.Mybatis环境搭建及简单实例 1. 新建web项目, 添加依赖包:mybatis包.数据库驱动包(我使用的是mysql).日志包(我使用的是log4j), 由于我的是maven项目, 那么添加 ...

  3. 【Java资源免费分享,网盘自己拿】

    JavaSE: Java马士兵:链接:https://pan.baidu.com/s/1jJRvxGi密码:v3xb Java毕向东:链接:https://pan.baidu.com/s/1ggzHk ...

  4. JAVA视频链接

    Java基础Java马士兵:链接:https://pan.baidu.com/s/1jJRvxGi密码:v3xb Java刘意:链接:https://pan.baidu.com/s/1kVZQCqr密 ...

  5. Java视频教程免费分享(网盘直接取)

    Java基础 Java马士兵:链接:https://pan.baidu.com/s/1jJRvxGi密码:v3xb Java刘意:链接:https://pan.baidu.com/s/1kVZQCqr ...

  6. Spring框架第一天(搭建项目)

    Spring框架 1.简介 1.1 Spring是什么 一个开源的框架,是JavaEE开源框架 Spring是分层的 Java SE/EE应用 full-stack 轻量级开源框架,以IoC(Inve ...

  7. MyBatis数据库连接的基本使用-补充Mapper映射器

    补充 Mapper映射器的使用: Mapper映射器,google添加.Mapper映射器是将mapper.xml中配置的sql id,parameterType和resultMap按照规则一一映射到 ...

  8. MyBatis数据库连接的基本使用-补充

    补充1  MyBatis使用过程中,返回值类型可能是Map,不一定是实体类 返回查询结果也可以是一个Map,不一定是实体类 (1)mybatis会先将查询结果返回为一个map,字段名作为key,字段值 ...

  9. Mybatis源码学习第六天(核心流程分析)之Executor分析(补充)

    补充上一章没有讲解的三个Executor执行器; 还是贴一下之前的代码吧;我发现其实有些分析注释还是写在代码里面比较好,方便大家理解,之前是我的疏忽,不好意思 @Override public < ...

  10. MyBatis的关联关系补充 多对多 继承

    多对多 一个学生有多个课程 一个课程有多个学生 思路分析 :使用一个中间表 用学生表和课程表的主键作为中间表的联合主键 1数据库表的设计 课程表 学生表 中间表 2/实体类的设计 课程类 public ...

随机推荐

  1. Grafana监控系统的构建与实践

    本文深入探讨了Grafana的核心技术.数据源集成.仪表盘与可视化构建以及监控与告警配置,旨在为专业从业者提供全面的Grafana技术指南. 关注[TechLeadCloud],分享互联网架构.云服务 ...

  2. Linux扩展篇-shell编程(十)-shell范式

    shell编程提供一个范式,有利于统一程序风格,增加可读性. 范式: ASSIGN SHELL/指定壳 DESCRIPTION/程序说明 BODY/程序体 扩展: 1.ASSIGN SHELL/指定壳 ...

  3. CompatTelRunner CPU 占用 22% win10 笔记本常常无故风扇狂转

    CompatTelRunner CPU 占用 22% win10 笔记本常常无故风扇狂转 CompatTelRunner.exe is also known as Windows Compatibil ...

  4. Prometheus + Grafana (2) mysql、redis、Docker容器、服务端点以及预警

    接着上一节 <Prometheus + Grafana (1) 监控 >,我们继续探讨 Prometheus + Grafana 的复杂应用 实现目标 这节我们的目标是搭建一个多维度监控微 ...

  5. WPF/C#:在DataGrid中显示选择框

    前言 在使用WPF的过程中可能会经常遇到在DataGrid的最前或者最后添加一列选择框的需求,今天跟大家分享一下,在自己的项目中是如何实现的. 整体实现效果如下: 如果对此感兴趣,可以接下来看具体实现 ...

  6. OSI七层网络模型和TCP/IP四层模型

    OSI七层网络模型 OSI: 开放系统互连参考模型是ISO制定的一个用于计算机或通信系统间互联的标准体系 OSI七层模型功能: 物理层: 七层模型的最底层,主要是物理介质传输媒介(网线或者无线),在不 ...

  7. 为什么不推荐使用Linq?

    相信很多.NETer看了标题,都会忍不住好奇,点进来看看,并且顺便准备要喷作者! 这里,首先要申明一下,作者本人也非常喜欢Linq,也在各个项目中常用Linq. 我爱Linq,Linq优雅万岁!!!( ...

  8. Android系统启动:.rc文件

    Android系统启动:.rc文件 reference : https://www.jianshu.com/p/a4c17f0110d0 以init.rc为例. .rc文件 init.rc文件由系统第 ...

  9. NXP i.MX 8M Mini开发板规格书(四核ARM Cortex-A53 + 单核ARM Cortex-M4,主频1.6GHz)

    1 评估板简介 创龙科技TLIMX8-EVM是一款基于NXP i.MX 8M Mini的四核ARM Cortex-A53 + 单核ARM Cortex-M4异构多核处理器设计的高性能评估板,由核心板和 ...

  10. Linux后台运行jar文件和关闭Java程序

    后台运行jar文件 Linux 运行jar包 java -jar jar文件名字.jar 这是最简单运行jar文件的命令. 特点:当前命令行窗口将被锁定,可按CTRL + C中止程序运行,或直接关闭窗 ...