MyBatis框架基础+进阶(二)(核心配置文件详解、Mybatis获取参数值的方式、MyBatis查询功能)

本文详细介绍了MyBatis中参数值的获取方式,包括字面量类型、map集合、实体类以及使用@Param注解的方法,并展示了不同方式的查询功能,如查询单个实体、list集合、map集合等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一、核心配置文件

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

封装SqlSessionUtils工具类,并测试功能

工具类:
package cn.hncj.utils;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

/**
 * Created on 2022/4/6.
 *
 * @author Hou chaof
 */
public class SqlSessionUtils {

    public static SqlSession getSqlSession() {
        SqlSession sqlSession = null;
        try {
    	    //1.加载核心配置文件
            InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
            //获取SqlSessionFactory
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
            //获取sqlSession
            sqlSession = sqlSessionFactory.openSession(true);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sqlSession;
    }
}

测试类:
import cn.hncj.mapper.ParameterMapper;
import cn.hncj.pojo.User;
import cn.hncj.utils.SqlSessionUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;


import java.util.List;

/**
 * Created on 2022/4/6.
 *
 * @author Hou chaof
 */
public class TestMapper {

    @Test
    public void testGetAllUser() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        //获取mapper接口对象
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        List<User> list = mapper.getAllUser();
        list.forEach(user -> System.out.println(user));

    }

}

测试结果如下:

在这里插入图片描述

二、MyBatis获取参数值的方式(重点)

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

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

	若mapper接口中的方法参数为单个的字面量类型
	此时可以使用${}和#{}以任意的名称获取参数的值,注意${}需要手动加单引号

*1.根据用户名查询用户信息,mapper接口方法参数为单个字面量类型


    //根据用户名查询用户信息,
    User getUserByUsername(String username);

2.映射文件
以下两种方式均可查询到用户信息,注意${}要有单引号。

<!--User  getUserByUsername(String username);-->
    <select id="getUserByUsername" resultType="User">
         select  * from  t_user where  username=#{username}
    </select>
<!--User  getUserByUsername(String username);-->
    <select id="getUserByUsername" resultType="User">
         select  * from  t_user where  username='${username}'
    </select>

测试类:

 @Test
    public void testGetUserByUsername() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = mapper.getUserByUsername("李四");
        System.out.println(user);
    }

输出结果:
在这里插入图片描述

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

若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中,以arg0,arg1...为键,以参数为值;
以param1,param2...为键,以参数为值;因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
//验证登录
    User checkLogin(String username ,String password);
 <!--User checkLogin(String username ,String password);-->
    <select id="checkLogin" resultType="User">
        select * from  t_user where username=#{arg0} and password=#{arg1};
    </select>
 @Test
    public void testcheckLogin() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = mapper.checkLogin("李四","123");
        System.out.println(user);
    }

2.3、map集合类型的参数

若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中。
只需要通过#{}访问map集合的键就可以获取相对应的值,注意使用${}需要手动加单引号

/验证登录
    User checkLoginMap(Map<String ,Object> map);
 <select id="checkLoginMap" resultType="User">
        select * from  t_user where username= #{username}and password= #{password};
    </select>
 @Test
    public void testcheckLoginByMap() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        Map<String, Object> map=new HashMap<>();
        map.put("username","李四");
        map.put("password","123");
        User user = mapper.checkLoginMap(map);
        System.out.println(user);
    }

2.4、实体类类型的参数(重点)

若mapper接口中的方法参数为实体类对象时,此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值


    //添加用户信息
    int insertUser(User user);
 <insert id="insertUser">
        insert into t_user values(null,#{username},#{password},#{age},#{sex},#{email})
    </insert>
 @Test
    public void testInsertUser() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        int i = mapper.insertUser(new User(null, "李ww四", "21", 23, "男", "131"));
        System.out.println(i);
    }

数据添加成功
在这里插入图片描述

2.5、使用@Param标识参数(重点)

通过@Param注解标识mapper接口中的方法参数
	此时,会将这些参数放在map集合中,以@Param注解的value属性值为键,以参数为值;以param1,param2...为键,以参数为值;
	只需要通过${}和#{}访问map集合的键就可以	获取相对应的值,
	注意${}需要手动加单引号
   //验证登录,加上注解后,mybatis会将这些参数放在map集合中,以@Param注解的值为键,以参数为值
    User checkLoginParam(@Param("username1") String username, @Param("password1") String password);
    <select id="checkLoginParam" resultType="User">
        select * from  t_user where username= #{username1}and password= #{password1};
    </select>
  @Test
    public void testcheckLoginParam() {
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        ParameterMapper mapper = sqlSession.getMapper(ParameterMapper.class);
        User user = mapper.checkLoginParam("李四","123");
        System.out.println(user);
    }

在这里插入图片描述

三、MyBatis的各种查询功能

3.1、查询一个实体类对象

Mapper接口:

public interface SelectMapper {
    //根据id查询用户信息
    User getUserById(@Param("id") Integer id);
}

Mapper接口映射文件:

<!--User getUserById(@Param("id") Integer id);-->
    <select id="getUserById" resultType="User">
        select  * from t_user where id=#{id};
    </select>

测试类:

public class TestSelect {
    @Test
    public void getUserById(){
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        System.out.println(mapper.getUserById(6));

    }
}

3.2、查询一个list集合

//查询所有用户信息
    List<User> getAllUser();
<!--//查询所有用户信息
    List<User> getAllUser();-->
    <select id="getAllUser" resultType="User">
        select * from t_user;
    </select>
 @Test
    public void getAllUser(){
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        System.out.println(mapper.getAllUser());
    }

3.3、查询一条数据为map集合

//根据id查询用户信息为一个map集合
    Map<String,Object> getUserMap(@Param("id") Integer id);
 <!--//根据id查询用户信息为一个map集合
    Map<String,Object> getUserMap();-->
    <select id="getUserMap" resultType="map">
        select * from t_user where id=#{id};
    </select>
 @Test
    public void getUserMap(){
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        System.out.println(mapper.getUserMap(14));
    }

在这里插入图片描述

3.4、查询多条数据为map集合(@Mapkey)

  //查询所有用户信息为map集合
    @MapKey("id")
    Map<String, Object> getAllUserMap();
<!--//查询所有用户信息为map集合
    Map<String, Object> getAllUserMap();-->
    <select id="getAllUserMap" resultType="map">
        select * from t_user;
    </select>
@Test
    public void getAllUserMap(){
        SqlSession sqlSession = SqlSessionUtils.getSqlSession();
        SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);
        System.out.println(mapper.getAllUserMap());
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值