【SSM框架】Mybatis详解08(源码自取)之优化注册,#{}与¥{}区别,返回主键,UUID

简介: 上一篇我们实现了动态代理这一篇我们将继续复习,优化mapper.xml文件注册,#{}占位符,${}字符串拼接或字符串替换,返回主键值,UUID和我一起复习下去你可以获得一个比较完美框架demo,并且深刻体会框架。坚持到最后的源码解析你会收获更多哦,加油坚持!!!

文章目录


优化mapper.xml文件注册


mapper.xml四种注册方式

<!--注册mapper.xml文件-->
    <mappers>
        <!--绝对路径注册-->
        <mapper url="/"></mapper>
        <!--非动态代理方式下的注册-->
        <mapper resource="StudentMapper.xml"></mapper>
        <!--动态代理方式下的单个mapper.xml文件注册-->
        <mapper class="com.bjpowernode.mapper.UsersMapper"></mapper>
        <!--批量注册-->
        <package name="com.bjpowernode.mapper"></package>
    </mappers> 

相比较而言,绝对路径注册比较局限,程序移植比较麻烦;第二种资源路径注册,少量mapper文件还可以,量比较多的时候注册就比较繁琐;第三种在动态代理中必须这样使用,以后使用比较多;第四种批量注册,更加方便,注意默认注册名称是 mapper文件名首字母小写的驼峰命名法,也比较常用。


#{}占位符


传参大部分使用#{}传参,它的底层使用的是PreparedStatement对象,是安全的数据库访问 ,防止sql注入.在使用#{}与¥{}的时候,大多数时候我们都是选用#{}哦。

#{}里如何写,看parameterType参数的类型

1)如果parameterType的类型是简单类型(8种基本(封装)+String),则#{}里随便写.


<select id="getById" parameterType="int" resultType="users">  ===> 入参类型是简单类型
     select id,username,birthday,sex,address
     from users
     where id=#{zar}  ===>随便写
 </select>
<!--eg:-->
<!--    //根据用户主键查用户
 Users getById(Integer id);
 -->
 <select id="getById" parameterType="int" resultType="users">
     select <include refid="allColumns"></include>
     from users
     where id=#{id}
 </select>

2)parameterType的类型是实体类的类型,则#{}里只能是类中成员变量的名称,而且区分大小写.


 <insert id="insert" parameterType="users" >  ==>  入参是实体类
        insert into users (username, birthday, sex, address) 
        values(#{userName},#{birthday},#{sex},#{address})  ==>成员变量名称
    </insert>
<!--eg:-->
<!--    //增加用户
    int add(Users users);
    private String userName;
    private Date birthday;
    private String sex;
    private String address;
    -->
    <insert id="add" parameterType="users">
    <selectKey keyProperty="id" resultType="int" order="AFTER">
        select last_insert_id()
    </selectKey>
        insert into users (username,birthday,sex,address)
        values (#{userName},#{birthday},#{sex},#{address})
    </insert>

${}字符串拼接或字符串替换


1)字符串拼接,一般用于模糊查询中.建议少用,因为有sql注入的风险.

也分两种情况,同样的看parameterType的类型


A. 如果parameterType的类型是简单类型,则${}里随便写,但是分版本,如果是3.5.1及以下的版本,只以写value.


<select id="getByName" parameterType="string" resultType="users">  <!--===>入参是简单类型-->
        select id,username,birthday,sex,address
        from users
        where username like '%${zar}%'   <!--===>随便写-->
    </select> 

B. 如果parameterType的类型是实体类的类型,则${}里只能是类中成员变量的名称.(现在已经少用)

C. 优化后的模糊查询(以后都要使用这种方式)

 <select id="getByNameGood" parameterType="string" resultType="users">
     select id,username,birthday,sex,address
     from users
     where username like concat('%',#{name},'%')
 </select>
<!--eg:-->
<!--    //优化后的模糊查询
 List<Users> getByNameGood(String name);
 -->
 <select id="getByNameGood" parameterType="string" resultType="users">
     select <include refid="allColumns"></include>
     from users
     where username like concat("%",#{name},"%")
 </select>

2)字符串替换

需求:模糊地址或用户名查询

select * from users where username like ‘%小%’;

select * from users where address like ‘%市%’

 <!--
   //模糊用户名和地址查询
   //如果参数超过一个,则parameterType不写
   List<Users> getByNameOrAddress(
           @Param("columnName")  ===>为了在sql语句中使用的名称
           String columnName,
           @Param("columnValue")   ===>为了在sql语句中使用的名称
           String columnValue);
   -->
   <select id="getByNameOrAddress" resultType="users">
       select id,username,birthday,sex,address
       from users
       where ${columnName} like concat('%',#{columnValue},'%') <!-- ==>此处使用的是@Param注解里的名称-->
   </select>

返回主键


当我们插入一条数据之后,我们需要拿着这个主键id去查找其他的值,或者需要查询新插入的id是多少,那么这个方法就用到了。

在插入语句结束后, 返回自增的主键值到入参的users对象的id属性中.

<insert id="insert" parameterType="users" >
      <selectKey  keyProperty="id" resultType="int" order="AFTER">
          select last_insert_id()
      </selectKey>
      insert into users (username, birthday, sex, address) values(#{userName},#{birthday},#{sex},#{address})
</insert>


标签的参数详解:

keyProperty: users对象的哪个属性来接返回的主键值

resultType:返回的主键的类型

order:在插入语句执行前,还是执行后返回主键的值


UUID


这是一个全球唯一随机字符串,由36个字母数字中划线组.

目前数据库中主键使用较多,当然获取唯一随机字符串的方法不止这一种。


 

  UUID uuid = UUID.randomUUID();
  System.out.println(uuid.toString().replace("-","").substring(20));

✨总结


今天主要复习了优化mapper.xml文件注册,#{}占位符,${}字符串拼接或字符串替换,返回主键值,UUID,小知识点比较碎,需要多看哦!!

下一篇我们将复习,动态sql!!!

本次源码放在代码仓库gitee,自取链接

相关文章
|
29天前
|
Java 数据库连接 Maven
手把手教你如何搭建SSM框架、图书商城系统案例
这篇文章是关于如何搭建SSM框架以及实现一个图书商城系统的详细教程,包括了项目的配置文件整合、依赖管理、项目结构和运行效果展示,并提供了GitHub源码链接。
手把手教你如何搭建SSM框架、图书商城系统案例
|
30天前
|
Java 数据库连接 Spring
后端框架入门超详细 三部曲 Spring 、SpringMVC、Mybatis、SSM框架整合案例 【爆肝整理五万字】
文章是关于Spring、SpringMVC、Mybatis三个后端框架的超详细入门教程,包括基础知识讲解、代码案例及SSM框架整合的实战应用,旨在帮助读者全面理解并掌握这些框架的使用。
后端框架入门超详细 三部曲 Spring 、SpringMVC、Mybatis、SSM框架整合案例 【爆肝整理五万字】
|
30天前
|
SQL Java 数据库连接
【Java 第十三篇章】MyBatis 框架介绍
MyBatis 原名 iBATIS,2001 年由 Clinton Begin 创建,以其简易灵活著称。2010 年更名以重塑品牌形象。MyBatis 通过 SQL 映射文件将 SQL 语句与 Java 代码分离,支持编写原生 SQL 并与方法映射。具备对象关系映射功能,简化数据库记录处理。支持动态 SQL 构建,灵活应对不同查询条件。内置缓存机制,提升查询效率。相比全功能 ORM,MyBatis 提供更高 SQL 控制度和更好的维护性,并易于与 Spring 等框架集成,广泛应用于 Java 数据访问层。
12 0
|
1月前
|
druid Java 数据库连接
SpringBoot项目整合MybatisPlus持久层框架+Druid数据库连接池,以及实现增删改查功能
SpringBoot项目整合MybatisPlus和Druid数据库连接池,实现基本的增删改查功能。
158 0
|
1月前
|
SQL Java 数据库连接
后端框架的学习----mybatis框架(5、分页)
这篇文章介绍了如何在MyBatis框架中实现分页功能,包括使用SQL的`limit`语句进行分页和利用MyBatis的`RowBounds`对象进行分页的方法。
|
6天前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
21天前
|
Java 数据库连接 测试技术
SpringBoot 3.3.2 + ShardingSphere 5.5 + Mybatis-plus:轻松搞定数据加解密,支持字段级!
【8月更文挑战第30天】在数据驱动的时代,数据的安全性显得尤为重要。特别是在涉及用户隐私或敏感信息的应用中,如何确保数据在存储和传输过程中的安全性成为了开发者必须面对的问题。今天,我们将围绕SpringBoot 3.3.2、ShardingSphere 5.5以及Mybatis-plus的组合,探讨如何轻松实现数据的字段级加解密,为数据安全保驾护航。
72 1
|
30天前
|
Web App开发 前端开发 关系型数据库
基于SpringBoot+Vue+Redis+Mybatis的商城购物系统 【系统实现+系统源码+答辩PPT】
这篇文章介绍了一个基于SpringBoot+Vue+Redis+Mybatis技术栈开发的商城购物系统,包括系统功能、页面展示、前后端项目结构和核心代码,以及如何获取系统源码和答辩PPT的方法。
|
1月前
|
Java 关系型数据库 MySQL
1、Mybatis-Plus 创建SpringBoot项目
这篇文章是关于如何创建一个SpringBoot项目,包括在`pom.xml`文件中引入依赖、在`application.yml`文件中配置数据库连接,以及加入日志功能的详细步骤和示例代码。
|
14天前
|
Java 数据库连接 开发者
MyBatis-Plus整合SpringBoot及使用
MyBatis-Plus为MyBatis提供了强大的增强,使得在Spring Boot项目中的数据访问层开发变得更加快捷和简便。通过MyBatis-Plus提供的自动CRUD、灵活的查询构造器和简洁的配置,开发者
29 0