文章目录
一、核心配置文件
核心配置文件中的标签必须按照固定的顺序:
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());
}