Mybatis之核心配置文件详解、默认类型别名、Mybatis获取参数值的两种方式

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 【1月更文挑战第3天】一、核心配置文件详解二、默认的类型别名三、MyBatis的增删改查四、MyBatis获取参数值的两种方式1、单个字面量类型的参数2、多个字面量类型的参数3、map集合类型的参数4、实体类类型的参数5、使用@Param标识参数


学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。各位小伙伴,如果您:

想系统/深入学习某技术知识点…

一个人摸索学习很难坚持,想组团高效学习…

想写博客但无从下手,急需写作干货注入能量…

热爱写作,愿意让自己成为更好的人…

文章目录

前言

一、核心配置文件详解

二、默认的类型别名

三、MyBatis的增删改查

四、MyBatis获取参数值的两种方式

1、单个字面量类型的参数

2、多个字面量类型的参数

3、map集合类型的参数

4、实体类类型的参数

5、使用@Param标识参数

总结


前言

一、核心配置文件详解

二、默认的类型别名

三、MyBatis的增删改查

四、MyBatis获取参数值的两种方式

1、单个字面量类型的参数

2、多个字面量类型的参数

3、map集合类型的参数

4、实体类类型的参数

5、使用@Param标识参数


一、核心配置文件详解

核心配置文件中的标签必须按照固定的顺序(有的标签可以不写,但顺序一定不能乱):

properties、settings、typeAliases、typeHandlers、objectFactory、objectWrapperFactory、reflectorFactory、plugins、environments、databaseIdProvider、mappers

<?xmlversion="1.0" encoding="UTF-8" ?><!DOCTYPE configurationPUBLIC "-//MyBatis.org//DTD Config 3.0//EN""http://MyBatis.org/dtd/MyBatis-3-config.dtd"><configuration><!--引入properties文件,此时就可以${属性名}的方式访问属性值--><propertiesresource="jdbc.properties"></properties><settings><!--将表中字段的下划线自动转换为驼峰--><settingname="mapUnderscoreToCamelCase"value="true"/><!--开启延迟加载--><settingname="lazyLoadingEnabled"value="true"/></settings><typeAliases><!--typeAlias:设置某个具体的类型的别名属性:type:需要设置别名的类型的全类名alias:设置此类型的别名,且别名不区分大小写。若不设置此属性,该类型拥有默认的别名,即类名--><!--<typeAlias type="com.atguigu.mybatis.bean.User"></typeAlias>--><!--<typeAlias type="com.atguigu.mybatis.bean.User" alias="user"></typeAlias>--><!--以包为单位,设置改包下所有的类型都拥有默认的别名,即类名且不区分大小写--><packagename="com.atguigu.mybatis.bean"/></typeAliases><!--environments:设置多个连接数据库的环境属性:default:设置默认使用的环境的id--><environmentsdefault="mysql_test"><!--environment:设置具体的连接数据库的环境信息属性:id:设置环境的唯一标识,可通过environments标签中的default设置某一个环境的id,表示默认使用的环境--><environmentid="mysql_test"><!--transactionManager:设置事务管理方式属性:type:设置事务管理方式,type="JDBC|MANAGED"type="JDBC":设置当前环境的事务管理都必须手动处理type="MANAGED":设置事务被管理,例如spring中的AOP--><transactionManagertype="JDBC"/><!--dataSource:设置数据源属性:type:设置数据源的类型,type="POOLED|UNPOOLED|JNDI"type="POOLED":使用数据库连接池,即会将创建的连接进行缓存,下次使用可以从缓存中直接获取,不需要重新创建type="UNPOOLED":不使用数据库连接池,即每次使用连接都需要重新创建type="JNDI":调用上下文中的数据源--><dataSourcetype="POOLED"><!--设置驱动类的全类名--><propertyname="driver"value="${jdbc.driver}"/><!--设置连接数据库的连接地址--><propertyname="url"value="${jdbc.url}"/><!--设置连接数据库的用户名--><propertyname="username"value="${jdbc.username}"/><!--设置连接数据库的密码--><propertyname="password"value="${jdbc.password}"/></dataSource></environment></environments><!--引入映射文件--><mappers><!-- <mapper resource="UserMapper.xml"/> --><!--以包为单位,将包下所有的映射文件引入核心配置文件注意:1. 此方式必须保证mapper接口和mapper映射文件必须在相同的包下2. mapper接口要和mapper映射文件的名字一致--><packagename="com.atguigu.mybatis.mapper"/></mappers></configuration>

二、默认的类型别名

三、MyBatis的增删改查

  1. 添加
<!--intinsertUser();--><insertid="insertUser">insertintot_uservalues(null,'admin','123456',23,'男','12345@qq.com')
</insert>
  1. 删除
<!--intdeleteUser();--><deleteid="deleteUser">deletefromt_userwhereid=6</delete>
  1. 修改
<!--int updateUser();--><update id="updateUser">update t_user set username ='张三'where id =5</update>
  1. 查询一个实体类对象
<!--UsergetUserById();--><selectid="getUserById"resultType="com.atguigu.mybatis.bean.User">select*fromt_userwhereid=2</select>
  1. 查询集合
<!--List<User>getUserList();--><selectid="getUserList"resultType="com.atguigu.mybatis.bean.User">select*fromt_user</select>
  • 注意:
  1. 查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射关系
  • resultType:自动映射,用于属性名和表中字段名一致的情况
  • resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况
  1. 当查询的数据为多条时,不能使用实体类作为返回值,只能使用集合,否则会抛出异常TooManyResultsException;但是若查询的数据只有一条,可以使用实体类或集合作为返回值

四、MyBatis获取参数值的两种方式

  • MyBatis获取参数值的两种方式:${}和#{}
  • ${}的本质就是字符串拼接,#{}的本质就是占位符赋值
  • ${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号

1、单个字面量类型的参数

  • 若mapper接口中的方法参数为单个的字面量类型,此时可以使用${}和#{}以任意的名称(最好见名识意)获取参数的值,注意${}需要手动加单引号
<!--UsergetUserByUsername(Stringusername);--><selectid="getUserByUsername"resultType="User">select*fromt_userwhereusername=#{username}
</select>
<!--UsergetUserByUsername(Stringusername);--><selectid="getUserByUsername"resultType="User">select*fromt_userwhereusername='${username}'</select>

2、多个字面量类型的参数

  • 若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中
  1. 以arg0,arg1…为键,以参数为值;
  2. 以param1,param2…为键,以参数为值;
  • 因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。
  • 使用arg或者param都行,要注意的是,arg是从arg0开始的,param是从param1开始的
<!--UsercheckLogin(Stringusername,Stringpassword);--><selectid="checkLogin"resultType="User">select*fromt_userwhereusername=#{arg0} andpassword=#{arg1}  
</select>
<!--UsercheckLogin(Stringusername,Stringpassword);--><selectid="checkLogin"resultType="User">select*fromt_userwhereusername='${param1}'andpassword='${param2}'</select>

3、map集合类型的参数

  • 若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
<!--UsercheckLoginByMap(Map<String,Object>map);--><selectid="checkLoginByMap"resultType="User">select*fromt_userwhereusername=#{username} andpassword=#{password}
</select>
@TestpublicvoidcheckLoginByMap() {
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
ParameterMappermapper=sqlSession.getMapper(ParameterMapper.class);
Map<String,Object>map=newHashMap<>();
map.put("usermane","admin");
map.put("password","123456");
Useruser=mapper.checkLoginByMap(map);
System.out.println(user);
}

4、实体类类型的参数

  • 若mapper接口中的方法参数为实体类对象时此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值,注意${}需要手动加单引号
<!--intinsertUser(Useruser);--><insertid="insertUser">insertintot_uservalues(null,#{username},#{password},#{age},#{sex},#{email})
</insert>
@TestpublicvoidinsertUser() { 
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
ParameterMappermapper=sqlSession.getMapper(ParameterMapper.class);
Useruser=newUser(null,"Tom","123456",12,"男","123@321.com");
mapper.insertUser(user);
}

5、使用@Param标识参数

  • 可以通过@Param注解标识mapper接口中的方法参数,此时,会将这些参数放在map集合中
  1. 以@Param注解的value属性值为键,以参数为值;
  2. 以param1,param2…为键,以参数为值;
  • 只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
<!--UserCheckLoginByParam(@Param("username") Stringusername, @Param("password") Stringpassword);--><selectid="CheckLoginByParam"resultType="User">select*fromt_userwhereusername=#{username} andpassword=#{password}
</select>
@TestpublicvoidcheckLoginByParam() {
SqlSessionsqlSession=SqlSessionUtils.getSqlSession();
ParameterMappermapper=sqlSession.getMapper(ParameterMapper.class);
mapper.CheckLoginByParam("admin","123456");
}
  • 建议分成两种情况进行处理
  1. 实体类类型的参数
  2. 使用@Param标识参数

总结

以上就是Mybatis之核心配置文件详解、默认类型别名、Mybatis获取参数值的两种方式的相关知识点,希望对你有所帮助。

积跬步以至千里,积怠惰以至深渊。时代在这跟着你一起努力哦!

相关文章
|
1月前
|
XML Java 数据库连接
mybatis环境搭建步骤(含配置文件代码)
mybatis环境搭建步骤(含配置文件代码)
15 1
|
3月前
|
SQL Java 数据库连接
初识MyBatis(搭建MyBatis、简单增删改查、核心配置文件讲解及获取参数值)
初识MyBatis(搭建MyBatis、简单增删改查、核心配置文件讲解及获取参数值)
|
1月前
|
缓存 Java 数据库连接
【MyBatis】主配置文件
【MyBatis】主配置文件
27 0
|
3月前
|
SQL Java 数据库连接
Mybatis之Mybatis简介、搭建Mybatis相关步骤(开发环境、maven、核心配置文件、mapper接口、映射文件、junit测试、log4j日志)
【1月更文挑战第2天】 MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下,iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)
203 3
Mybatis之Mybatis简介、搭建Mybatis相关步骤(开发环境、maven、核心配置文件、mapper接口、映射文件、junit测试、log4j日志)
|
1月前
|
XML Java 数据库连接
【MyBatis】1、MyBatis 核心配置文件、多表查询、实体映射文件 ......
【MyBatis】1、MyBatis 核心配置文件、多表查询、实体映射文件 ......
51 0
|
5天前
|
XML Java 数据库连接
Javaweb之Mybatis的XML配置文件的详细解析
Javaweb之Mybatis的XML配置文件的详细解析
13 0
|
1月前
|
Java 数据库连接 mybatis
Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
Mybatis+mysql动态分页查询数据案例——Mybatis的配置文件(mybatis-config.xml)
20 1
|
1月前
|
SQL Java 数据库连接
Mybatis查询的时候BigDecimal类型的值查询失效的解决办法
Mybatis查询的时候BigDecimal类型的值查询失效的解决办法
|
1月前
|
SQL Java 数据库连接
Mybatis拦截器实现带参数SQL语句打印
Mybatis拦截器实现带参数SQL语句打印

热门文章

最新文章

  • 1
    Serverless 应用引擎产品使用之在函数计算中,数据库访问失败如何解决
    5
  • 2
    Serverless 应用引擎产品使用之在阿里云函数计算中发现没有NAC(Native Application Component)选项,且无法自己上传MOD(模块)如何解决
    5
  • 3
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,调用了FC函数但是没有执行或者报错,并且在FC函数后台也看不到调用记录日志如何解决
    7
  • 4
    Serverless 应用引擎操作报错合集之在阿里函数计算中,sd部署启动报错CAExited 报错信息“operation not permitted”如何解决
    5
  • 5
    Serverless 应用引擎操作报错合集之在阿里函数计算中,SD Controlnet Depth 运行过程中出现错误“urllib3 v2.0 only supports OpenSSL 1.1.1+”如何解决
    6
  • 6
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,laravel zip包使用示例的start.sh脚本启动时出现错误代码如何解决
    7
  • 7
    Serverless 应用引擎操作报错合集之在阿里云函数计算中,服务器调用FC函数时出现 "[Errno -3] Temporary failure in name resolution)" 错误如何解决
    5
  • 8
    Serverless 应用引擎操作报错合集之在Serverless 应用引擎中,部署过程中遇到错误代码如何解决
    9
  • 9
    Serverless 应用引擎操作报错合集之在 Serverless 应用引擎中,遇到“没法通过 head 传递灰度标识”如何解决
    5
  • 10
    Serverless 应用引擎操作报错合集之在阿里函数计算中,函数执行超时,报错Function time out after如何解决
    11