Mybatis是一个优秀的Java持久层框架,它提供了强大的数据库访问能力和灵活的SQL映射配置。下面将从基本使用、配置文件、映射文件和动态SQL几个方面来介绍Mybatis的代码教程。
一、基本使用
- 引入依赖:在项目的pom.xml文件中添加Mybatis的依赖。
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
- 配置数据源:在项目的配置文件中配置数据库连接信息。
<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>
- 编写映射文件:在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>
- 编写Mapper接口:创建UserMapper接口,并定义方法。
public interface UserMapper {
User getUserById(int id);
}
- 编写配置文件:在resources目录下创建mybatis-config.xml文件,配置Mapper接口的扫描路径。
<configuration>
<mappers>
<package name="com.example.mapper"/>
</mappers>
</configuration>
- 执行查询:在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();
二、配置文件
-
数据库连接配置:在配置文件中配置数据库连接信息,包括驱动、URL、用户名和密码等。
-
映射文件位置:在配置文件中指定映射文件的位置。
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
- 缓存配置:在配置文件中配置一级缓存和二级缓存。
<configuration>
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
</configuration>
三、映射文件
-
namespace:映射文件的命名空间,与Mapper接口的全限定名保持一致。
-
select:查询语句。
<select id="getUserById" resultType="com.example.model.User">
SELECT * FROM user WHERE id = #{id}
</select>
- insert、update、delete:插入、更新、删除语句。
<insert id="insertUser" parameterType="com.example.model.User">
INSERT INTO user(name, age) VALUES (#{name}, #{age})
</insert>
四、动态SQL
- if标签:根据条件动态拼接SQL语句。
<select id="getUserByCondition" resultType="com.example.model.User">
SELECT * FROM user
<where>
<if test="name != null">
AND name = #{name```