mybatis----小细节

1、起别名

在MyBatis中,<typeAliases>元素用于定义类型别名,它可以将Java类名映射为一个更简短的别名,这样在映射文件中可以直接使用别名而不需要完整的类名。

下面是一个示例:

mybatis核心配置文件中配置typeAliases标签

复制代码
  1. <typeAliases>

  2. <typeAlias alias="Acount" type="duhong.entity.Account"/>

  3. </typeAliases>

为duhong.entity.Account类指定了别名Account。

定义了这些别名后,我们可以在映射文件中直接使用这些别名来引用对应的Java类,例如:

复制代码
<resultMap id="AccountMap" type="Account">

通过使用别名,我们可以简化映射文件中的配置,并提高代码可读性和可维护性。

2、mybatis核心配置文件加载映射文件的其他方式
复制代码
<package name="duhong.dao"/>

这种声明方式,会使mybatis查找duhong/dao下对应的xml文件,不过这种方式要求xml资源目录与dao层目录一致,而且xml名称要与mapper接口名称一致。

3、#{}与${}的区别

在MyBatis中,#{} 和 ${} 用于处理SQL语句中的参数,但是它们在作用和安全性方面有所不同。

  1. #{} 语法:
    在MyBatis中,当你使用 #{} 来表示一个参数占位符时,MyBatis会在运行时将其替换为一个参数的值,并且会使用预处理语句(PreparedStatement)来处理参数。也就是说,不管参数值是什么,它都会被视为一个字符串值并且正确地转义。

    SELECT * FROM some_table WHERE id = #{id}

  2. {} 语法: 与 #{} 不同,当你使用 {} 时,MyBatis会直接将这个位置替换为变量的字面值。也就是说,如果你的变量中包含了特定的SQL关键词或结构,它将不做任何转义直接嵌入SQL语句中。

    SELECT * FROM ${tableName} WHERE column = #{value}

测试:

dao层添加接口

复制代码
  1. //查询所有,按降序排列

  2. List<Account> selectAllByDesc(String key);

mapper中添加查询语句

复制代码
  1. resultMap id="AccountMap" type="duhong.entity.Account">

  2. <id property="id" column="id"></id>

  3. <result property="accountNumber" column="account_number"></result>

  4. <result property="accountType" column="account_type"></result>

  5. <result property="balance" column="balance"></result>

  6. </resultMap>

  7. <select id="selectAllByDesc" resultMap="AccountMap">

  8. select * from account ORDER BY balance ${order};

  9. </select>

添加junit,测试

复制代码
  1. SqlSession sqlSession= SqlSessionUtil.openSession();

  2. @Test

  3. public void test(){

  4. AccountDao mapper = sqlSession.getMapper(AccountDao.class);

  5. List<Account> account = mapper.selectAllByDesc("DESC");

  6. for (Account account1 : account) {

  7. System.out.println(account);

  8. }

  9. }

将${}换成#{},执行出错,原因在于DESC是sql语句的关键字,而#{}会将参数转化为字符串。

4、模糊查询
复制代码
  1. <select id="selectLikeAll" resultMap="AccountMap">

  2. select * from account where account_number like '%${key}%';

  3. </select>

复制代码
  1. //模糊查询

  2. List<Account> selectLikeAll(String key);

复制代码
  1. @Test

  2. public void likeTest(){

  3. AccountDao accountDao=sqlSession.getMapper(AccountDao.class);

  4. List<Account> accounts = accountDao.selectLikeAll("1");

  5. System.out.println(accounts);

  6. }

同样直接使用#{}也会出错,#{}在' '中并不会被赋值

改进方式sql中使用concat拼接字符串

复制代码
  1. <select id="selectLikeAll" resultMap="AccountMap">

  2. select * from account where account_number like concat('%',#{key},'%');

  3. </select>

相关推荐
白帽子黑客罗哥5 分钟前
常见Web安全漏洞全解析:从原理到防御的实战指南
数据库·web安全·渗透测试·漏洞利用·权限提升
寒山李白2 小时前
IDEA连接MySQL服务器数据库指南
java·数据库·mysql·intellij-idea·idea·database
亿坊电商5 小时前
PHP后端项目中多环境配置管理:开发、测试、生产的优雅解决方案!
服务器·数据库·php
韩立学长5 小时前
基于Springboot的影视评论网站的设计与实现58py6238(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
未来之窗软件服务5 小时前
未来之窗昭和仙君(四十七)开发商品进销存——东方仙盟筑基期
数据库·进销存·仙盟创梦ide·东方仙盟·昭和仙君·东方仙盟架构
IDOlaoluo7 小时前
TinyRDM 1.2.3 Windows版安装教程(附Redis客户端下载及详细步骤)
数据库·redis·缓存
小光学长7 小时前
基于微信小程序的背单词系统x1o5sz72(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·微信小程序·小程序
我命由我123458 小时前
Derby - Derby 服务器(Derby 概述、Derby 服务器下载与启动、Derby 连接数据库与创建数据表、Derby 数据库操作)
java·运维·服务器·数据库·后端·java-ee·后端框架
W.Buffer9 小时前
MyBatis 源码深度解析:从 Spring Boot 实战到底层原理
spring boot·后端·mybatis
RestCloud10 小时前
达梦数据库到Greenplum:用ETL工具实现数据仓库迁移
数据库·数据仓库·etl·达梦数据库·数据传输·greenplum