Mybatis实操

301 阅读2分钟

Mybatis是一个优秀的Java持久层框架,它提供了强大的数据库访问能力和灵活的SQL映射配置。下面将从基本使用、配置文件、映射文件和动态SQL几个方面来介绍Mybatis的代码教程。

一、基本使用

  1. 引入依赖:在项目的pom.xml文件中添加Mybatis的依赖。
<dependency>
  <groupId>org.mybatis</groupId>
  <artifactId>mybatis</artifactId>
  <version>3.5.6</version>
</dependency>
  1. 配置数据源:在项目的配置文件中配置数据库连接信息。
<configuration>
  <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://localhost:3306/test"/>
        <property name="username" value="root"/>
        <property name="password" value="123456"/>
      </dataSource>
    </environment>
  </environments>
</configuration>
  1. 编写映射文件:在resources目录下创建UserMapper.xml文件,并定义SQL语句。
<mapper namespace="com.example.mapper.UserMapper">
  <select id="getUserById" resultType="com.example.model.User">
    SELECT * FROM user WHERE id = #{id}
  </select>
</mapper>
  1. 编写Mapper接口:创建UserMapper接口,并定义方法。
public interface UserMapper {
  User getUserById(int id);
}
  1. 编写配置文件:在resources目录下创建mybatis-config.xml文件,配置Mapper接口的扫描路径。
<configuration>
  <mappers>
    <package name="com.example.mapper"/>
  </mappers>
</configuration>
  1. 执行查询:在Java代码中获取SqlSession并执行查询。
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
User user = userMapper.getUserById(1);
System.out.println(user.getName());
sqlSession.close();

二、配置文件

  1. 数据库连接配置:在配置文件中配置数据库连接信息,包括驱动、URL、用户名和密码等。

  2. 映射文件位置:在配置文件中指定映射文件的位置。

<mappers>
  <mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
  1. 缓存配置:在配置文件中配置一级缓存和二级缓存。
<configuration>
  <settings>
    <setting name="cacheEnabled" value="true"/>
  </settings>
</configuration>

三、映射文件

  1. namespace:映射文件的命名空间,与Mapper接口的全限定名保持一致。

  2. select:查询语句。

<select id="getUserById" resultType="com.example.model.User">
  SELECT * FROM user WHERE id = #{id}
</select>
  1. insert、update、delete:插入、更新、删除语句。
<insert id="insertUser" parameterType="com.example.model.User">
  INSERT INTO user(name, age) VALUES (#{name}, #{age})
</insert>

四、动态SQL

  1. if标签:根据条件动态拼接SQL语句。
<select id="getUserByCondition" resultType="com.example.model.User">
  SELECT * FROM user
  <where>
    <if test="name != null">
      AND name = #{name```