MyBatis是一个优秀的持久层框架,支持定制化SQL查询和存储过程。本文将详细介绍MyBatis入门的相关内容,包括环境搭建、基本使用和高级特性。通过实例,读者将学会如何使用MyBatis进行数据库操作。MyBatis入门旨在帮助初学者快速上手并掌握MyBatis的核心概念和技术。
MyBatis入门:初学者指南 MyBatis简介MyBatis是什么
MyBatis是一个优秀的持久层框架,它支持定制化SQL查询,存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集的代码,提供了简单的XML或注解配置和原始映射。它将接口和Java的POJOs(普通的Java对象)映射成数据库中的记录。
MyBatis与Hibernate的区别
MyBatis是持久层框架,而Hibernate则是ORM框架。ORM(对象关系映射)是一种编程技术,它通过使用“对象”的概念来处理数据库表中的数据。Hibernate是全自动的ORM框架,会自动生成SQL语句,而MyBatis则是半自动的,需要程序员自行编写SQL语句。因此,MyBatis在一定程度上降低了程序的可移植性,但它提供了更细粒度的控制和性能优化的机会。
MyBatis的核心概念
MyBatis的核心概念包括配置文件、SqlSession、Mapper、Executor、ParameterHandler、ResultSetHandler、StatementHandler、TypeHandler等。配置文件是MyBatis的配置中心,SqlSession是MyBatis提供的执行SQL语句的接口,Mapper则是映射接口,它包含了所有与数据库相关操作的映射。
安装与环境搭建下载并安装MyBatis
要使用MyBatis,首先需要确保你的计算机上安装了Java开发环境。MyBatis是纯Java实现的,因此它在任何支持Java的平台上都可以运行。
下载MyBatis可以从其官方网站获取,网址为https://mybatis.org/mybatis-3/。你可以选择适合你的版本进行下载。
创建项目并引入MyBatis依赖
在你选择的集成开发环境(IDE)中创建一个新的Java项目。假设你正在使用Maven作为项目管理工具,你可以在项目的pom.xml
文件中添加以下依赖:
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.24</version>
</dependency>
</dependencies>
配置数据库连接
在项目中创建一个mybatis-config.xml
配置文件来配置数据库连接信息。配置文件中需要配置数据库的基本信息,如驱动类名、URL、数据库用户名和密码等。
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mydatabase"/>
<property name="username" value="root"/>
<property name="password" value="password"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/UserMapper.xml"/>
</mappers>
</configuration>
上面的配置文件中,<environment>
标签定义了开发环境的事务管理和数据源,<configuration>
标签包含了整个配置信息,<mappers>
标签定义了映射文件的位置。
创建数据映射文件
在MyBatis中需要单独编写SQL映射文件,这个文件通常位于src/main/resources
目录下。映射文件定义了所有SQL语句,以及如何映射结果集到Java对象。
例如,创建一个UserMapper.xml
映射文件:
<mapper namespace="com.example.UserMapper">
<select id="selectUser" resultType="com.example.User">
SELECT id, username, password FROM users WHERE id = #{id}
</select>
<insert id="insertUser">
INSERT INTO users (id, username, password) VALUES (#{id}, #{username}, #{password})
</insert>
</mapper>
编写SQL语句
在映射文件中,我们定义了selectUser
和insertUser
两个SQL语句,用于查询和插入用户数据。
实现Java代码与MyBatis的交互
在Java代码中,我们可以通过SqlSession对象执行SQL语句。首先,需要创建SqlSession对象,然后通过它来执行映射器中的SQL语句。
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.InputStream;
public class MyBatisExample {
public static void main(String[] args) throws Exception {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
try (SqlSession session = sqlSessionFactory.openSession()) {
UserMapper mapper = session.getMapper(UserMapper.class);
User user = mapper.selectUser(1);
System.out.println(user.getUsername());
}
}
}
在Java代码中,我们首先加载MyBatis的配置文件,创建SqlSessionFactory对象,然后通过SqlSession对象执行映射器中的SQL语句,最后返回结果对象。
MyBatis的高级特性使用动态SQL
MyBatis提供了动态SQL的支持,允许根据不同的条件生成不同的SQL语句。这主要通过<if>
、<choose>
、<when>
、<otherwise>
等标签实现。
<select id="selectUser" resultType="com.example.User">
SELECT id, username, password FROM users
<where>
<if test="id != null">
AND id = #{id}
</if>
<if test="username != null">
AND username = #{username}
</if>
</where>
</select>
参数和结果的类型映射
MyBatis提供了多种类型映射机制,包括基本类型、复杂类型、集合类型等。例如,对于基本类型,可以直接在SQL语句中使用#{}
占位符来表示参数;对于复杂类型,使用resultType
或resultMap
来映射结果集到Java对象。
<select id="selectUsers" resultType="com.example.User">
SELECT id, username, password FROM users
</select>
分页查询
MyBatis提供了分页查询的支持,可以通过LIMIT
和OFFSET
子句来实现。
<select id="selectUsers" resultType="com.example.User">
SELECT id, username, password FROM users
LIMIT #{offset}, #{limit}
</select>
在Java代码中,可以通过传递offset
和limit
参数来实现分页查询。
MyBatis中的事务管理
MyBatis支持JDBC和Spring两种事务管理方式。在配置文件中,可以通过定义不同的<transactionManager>
标签来实现不同的事务管理方式。
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mydatabase"/>
<property name="username" value="root"/>
<property name="password" value="password"/>
</dataSource>
</environment>
</environments>
MyBatis的缓存机制及其配置
MyBatis支持一级缓存(SqlSession缓存)和二级缓存(Mapper缓存)。一级缓存默认开启,二级缓存需要在全局配置文件中开启设置。
<cache-ref default="true"/>
在映射文件中,可以通过<cache>
标签来开启二级缓存:
<mapper namespace="com.example.UserMapper">
<cache/>
<select id="selectUser" resultType="com.example.User">
SELECT id, username, password FROM users WHERE id = #{id}
</select>
</mapper>
实践与案例
MyBatis的简单CRUD操作实例
这个案例展示了如何使用MyBatis进行基本的CRUD操作。首先创建一个简单的User
实体类和UserMapper
接口:
public class User {
private int id;
private String username;
private String password;
// getters and setters
}
public interface UserMapper {
User selectUser(int id);
int insertUser(User user);
int updateUser(User user);
int deleteUser(int id);
}
然后在映射文件中定义相应的SQL语句:
<mapper namespace="com.example.UserMapper">
<select id="selectUser" resultType="com.example.User">
SELECT id, username, password FROM users WHERE id = #{id}
</select>
<insert id="insertUser">
INSERT INTO users (id, username, password) VALUES (#{id}, #{username}, #{password})
</insert>
<update id="updateUser">
UPDATE users SET username = #{username}, password = #{password} WHERE id = #{id}
</update>
<delete id="deleteUser">
DELETE FROM users WHERE id = #{id}
</delete>
</mapper>
在Java代码中,可以实现对用户的增删改查操作:
public class MyBatisCRUDExample {
public static void main(String[] args) throws Exception {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
try (SqlSession session = sqlSessionFactory.openSession()) {
UserMapper mapper = session.getMapper(UserMapper.class);
// Insert
User user = new User();
user.setId(1);
user.setUsername("admin");
user.setPassword("123456");
int insertResult = mapper.insertUser(user);
System.out.println("Insert Result: " + insertResult);
// Select
User selectedUser = mapper.selectUser(1);
System.out.println("Selected User: " + selectedUser.getUsername());
// Update
selectedUser.setUsername("admin_new");
int updateResult = mapper.updateUser(selectedUser);
System.out.println("Update Result: " + updateResult);
// Delete
int deleteResult = mapper.deleteUser(1);
System.out.println("Delete Result: " + deleteResult);
}
}
}
MyBatis在小型项目中的应用
假设我们正在开发一个简单的图书管理系统,需要实现图书的增删改查功能。
首先,创建一个Book
实体类和BookMapper
接口:
public class Book {
private int id;
private String title;
private String author;
private double price;
// getters and setters
}
public interface BookMapper {
Book selectBook(int id);
int insertBook(Book book);
int updateBook(Book book);
int deleteBook(int id);
}
然后在映射文件中定义相应的SQL语句:
<mapper namespace="com.example.BookMapper">
<select id="selectBook" resultType="com.example.Book">
SELECT id, title, author, price FROM books WHERE id = #{id}
</select>
<insert id="insertBook">
INSERT INTO books (id, title, author, price) VALUES (#{id}, #{title}, #{author}, #{price})
</insert>
<update id="updateBook">
UPDATE books SET title = #{title}, author = #{author}, price = #{price} WHERE id = #{id}
</update>
<delete id="deleteBook">
DELETE FROM books WHERE id = #{id}
</delete>
</mapper>
在Java代码中,可以实现对图书的增删改查操作:
public class MyBatisBookSystem {
public static void main(String[] args) throws Exception {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
try (SqlSession session = sqlSessionFactory.openSession()) {
BookMapper mapper = session.getMapper(BookMapper.class);
// Insert
Book book = new Book();
book.setId(1);
book.setTitle("Clean Code");
book.setAuthor("Robert C. Martin");
book.setPrice(39.99);
int insertResult = mapper.insertBook(book);
System.out.println("Insert Result: " + insertResult);
// Select
Book selectedBook = mapper.selectBook(1);
System.out.println("Selected Book: " + selectedBook.getTitle());
// Update
selectedBook.setAuthor("Robert C. Martin New");
int updateResult = mapper.updateBook(selectedBook);
System.out.println("Update Result: " + updateResult);
// Delete
int deleteResult = mapper.deleteBook(1);
System.out.println("Delete Result: " + deleteResult);
}
}
}