目录
前言
MyBatis的具体使用
一些小工具:MyBatisX
常见问题:
1.表中字段名和实体属性名不一致
2.按条件查询(单条件)时的,查询条件怎么编写
3.按条件查询(多条件)
4.多条件查询时,用户不把所有条件填完
5.单条件查询时,不知道用户到底选了哪一个
6.添加用户怎么写接口和mapper.xml
7.添加信息时,如果要主键增长呢
8.修改信息
9.删除一行数据
10.批量删除☆☆☆
MyBatis注解
增
删
改
查
前言
为什么要有MyBatis呢?
当然是因为JDBC代码太繁琐啦~
上图标1的代码有很多字符串,而这些是连接数据库的四个基本信息,以后如果要将Mysql数据库换成其他的关系型数据库的话,这四个地方都需要修改,如果放在此处就意味着要修改我们的源代码。
上图标2的代码。如果表结构发生变化,SQL语句就要进行更改。这也不方便后期的维护。
操作很繁琐
使用MyBatis就可以解决这些问题
MyBatis的具体使用
1.创建一个表。
2.导入依赖坐标
3.在项目的resources 目录下创建mybatis的配置文件 mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 配置别名 -->
<!-- 这样的话,就在UserMapper中可以不用设置成这样了 -->
<!-- <select id="selectAll" resultType="org.example.pojo.User">-->
<!-- 因为在mybatis中配置了别名,所以可以不用谢前面的包名了 -->
<!-- <select id="selectAll" resultType="User">-->
<typeAliases>
<package name="org.example.pojo"/>
</typeAliases>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<!-- 这一段代码是连接信息 -->
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///mybatis?useSSL=false"/>
<property name="username" value="root"/>
<property name="password" value="1234"/>
</dataSource>
</environment>
</environments>
<!-- 指定sql映射的路径 -->
<!-- 因为在resource目录上有和src目录下的下相同目录,所以直接可以使用package包的方式 -->
<mappers>
<!-- <mapper resource="org/example/mapper/UserMapper.xml"/>-->
<package name="org.example.mapper"/>
</mappers>
</configuration>
4.创建实体类User
public class User {
private int id;
private String username;
private String password;
private String gender;
private String addr;
//省略了 setter 和 getter
}
5.在模块的 resources 目录下创建映射配置文件 UserMapper.xml
SQL语句就是在**Mapper.xml文件中编写的
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="test">
<select id="selectAll" resultType="com.itheima.pojo.User">
select * from tb_user;
</select>
</mapper>
需要满足这样的目录层级
6.定义UserMapper接口代码
public interface UserMapper {
List<User> selectAll();
}
注意层级和名称一致问题
7.定义一个测试类进行测试
/**
* Mybatis 代理开发
*/
public class MyBatisDemo2 {
public static void main(String[] args) throws IOException {
//1. 加载mybatis的核心配置文件,获取 SqlSessionFactory
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//2. 获取SqlSession对象,用它来执行sql
SqlSession sqlSession = sqlSessionFactory.openSession();
//3. 执行sql
//3.1 获取UserMapper接口的代理对象
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
List<User> users = userMapper.selectAll();
System.out.println(users);
//4. 释放资源
sqlSession.close();
}
}
一些小工具:MyBatisX
MyBatisX 插件
-
XML映射配置文件 和 接口方法 间相互跳转
-
根据接口方法生成 statement
如下图操作就可以完成,生成Mapper.xml文件中的statement
常见问题:
1.表中字段名和实体属性名不一致
使用Mybatis时,可能会出现数据库表的字段名称和实体类的属性名称不一样的问题,这样的话就不能自动封装数据了。
可以resultMap
具体来说:就是在 **Mapper.xml中添加下图红框框住的<resultMap></resultMap>部分,对字段进行映射,下图中前面的字段是数据库中的命名,后面是实体类的属性名。
然后将resultType换成resultMap
2.按条件查询(单条件)时的,查询条件怎么编写
在 **Mapper中这样写,如下图查询条件是id 就这样写#{id}
对于有参数的Mapper接口方法
3.按条件查询(多条件)
可以使用以下三种方法
mapper.xml的编写
在测试类中的调用
4.多条件查询时,用户不把所有条件填完
这个时候就要使用到动态SQL
使用<where></where>标签 和 <if></if>标签
5.单条件查询时,不知道用户到底选了哪一个
这种需求需要使用到 choose(when,otherwise)标签 实现, 而 choose 标签类似于Java 中的switch语句。
6.添加用户怎么写接口和mapper.xml
定义接口
写mapper,使用的是<insert></insert>
封装对象,执行方法
7.添加信息时,如果要主键增长呢
添加
useGeneratedKeys, keyProperty 关键字
8.修改信息
定义接口
编写mapper.xml
执行方法
9.删除一行数据
10.批量删除☆☆☆
编写SQL时需要遍历数组来拼接SQL语句。Mybatis 提供了 foreach 标签供我们使用
MyBatis注解
注解是用来替换映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中书写对应的 statement。
使用注解开发会比配置文件开发更加方便。如下就是使用注解进行开发。
但是对于复杂的SQL语句还是建议使用配置文件的方法。
增
public interface UserMapper {
@Insert("INSERT INTO users(username, age) VALUES(#{username}, #{age})")
int insertUser(User user);
}
删
public interface UserMapper {
@Delete("DELETE FROM users WHERE id = #{id}")
int deleteUserById(@Param("id") int id);
}
改
public interface UserMapper {
@Update("UPDATE users SET username = #{username}, age = #{age} WHERE id = #{id}")
int updateUser(User user);
}
查
public interface UserMapper {
@Select("SELECT * FROM users WHERE id = #{id}")
User selectUserById(@Param("id") int id);
// 查询所有用户
@Select("SELECT * FROM users")
List<User> selectAllUsers();
}