MyBatis是一款基于Java的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索,使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plain Ordinary Java Objects,普通的Java对象)映射成数据库中的记录。以下是对MyBatis的详细解释,并通过一个实例来形象地展示其使用。


一、MyBatis概述

MyBatis本是Apache的一个开源项目iBatis,2010年这个项目由Apache Software Foundation迁移到了Google Code,并且改名为MyBatis。2013年11月,MyBatis迁移到GitHub。MyBatis支持普通SQL查询、存储过程和高级映射,是一个轻量级、易于学习且功能强大的持久层框架,适用于各种规模的Java应用程序。

MyBatis的核心思想是通过XML或注解的方式将Java对象与数据库中的表进行映射,从而简化数据库操作。它提供了DAO(Data Access Object)层,将业务逻辑和数据访问逻辑分离,使得系统的设计更清晰、更易维护、更易单元测试。

二、MyBatis的功能特点

  1. 简单易学:MyBatis本身很小且简单,没有任何第三方依赖,最简单安装只要两个jar文件加上配置几个SQL映射文件。通过文档和源代码,开发者可以比较完全地掌握其设计思路和实现。
  2. 灵活性强:MyBatis不会对应用程序或者数据库的现有设计强加任何影响。SQL写在XML里,便于统一管理和优化。通过SQL语句可以满足操作数据库的所有需求。
  3. 解除SQL与程序代码的耦合:MyBatis通过提供DAO层,将业务逻辑和数据访问逻辑分离,提高了系统的可维护性和可扩展性。
  4. 支持对象与数据库的ORM字段关系映射:MyBatis提供了映射标签,支持对象与数据库的ORM(Object-Relational Mapping,对象关系映射)字段关系映射,使得开发者可以更加便捷地进行数据库操作。

三、MyBatis的实例讲解

以下是一个简单的MyBatis使用实例,以展示其如何进行数据库操作。

1. 数据库和数据表的创建

首先,需要创建一个数据库和一个数据表。例如,创建一个名为testdb的数据库和一个名为user的数据表,表结构如下:

sql
CREATE DATABASE testdb;
USE testdb;
CREATE TABLE user (
id INT PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(100) NOT NULL,
password VARCHAR(32) NOT NULL,
createtime TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

2. MyBatis开发环境的配置

接下来,需要配置MyBatis的开发环境。这包括添加MyBatis框架依赖、配置数据库连接信息等。

(1)在项目的pom.xml文件中添加MyBatis框架依赖(以Maven项目为例):

xml
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>最新版本号</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>最新版本号</version>
<scope>runtime</scope>
</dependency>

(2)在resources目录下创建MyBatis的配置文件mybatis-config.xml,配置数据库连接信息:

xml
<?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>
<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/testdb?useSSL=false&serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="yourpassword"/>
</dataSource>
</environment>
</environments>
<mappers>
<mapper resource="com/example/mapper/UserMapper.xml"/>
</mappers>
</configuration>

(3)在com/example/mapper目录下创建UserMapper.xml文件,配置SQL映射:

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="com.example.mapper.UserMapper">
<insert id="insertUser" parameterType="com.example.model.User">
INSERT INTO user (username, password)
VALUES (#{username}, #{password})
</insert>
<select id="selectUserById" parameterType="int" resultType="com.example.model.User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>

3. 编写Java代码进行数据库操作

最后,编写Java代码来执行数据库操作。例如,创建一个User类来对应数据库中的user表,并编写一个UserMapper接口来定义数据库操作方法。然后,通过MyBatis的API来执行这些方法。

java
// User.java
package com.example.model;
public class User {
private int id;
private String username;
private String password;
private Timestamp createtime;
// Getters and Setters
}
// UserMapper.java
package com.example.mapper;
import com.example.model.User;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Select;
public interface UserMapper {
@Insert("INSERT INTO user (username, password) VALUES (#{username}, #{password})")
void insertUser(User user);
@Select("SELECT * FROM user WHERE id = #{id}")
User selectUserById(int id);
}
// Main.java
package com.example;
import com.example.mapper.UserMapper;
import com.example.model.User;
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.Reader;
import java.sql.Timestamp;
public class Main {
public static void main(String[] args) throws IOException {
String resource = "mybatis-config.xml";
Reader reader = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
try (SqlSession session = sqlSessionFactory.openSession()) {
UserMapper mapper = session.getMapper(UserMapper.class);
User user = new User();
user.setUsername("testuser");
user.setPassword("testpassword");
mapper.insertUser(user);
session.commit();
User selectedUser = mapper.selectUserById(user.getId());
System.out.println(selectedUser);
}
}
}

在这个例子中,我们首先配置了MyBatis的开发环境,包括添加框架依赖、配置数据库连接信息和SQL映射文件。然后,我们编写了一个User类来对应数据库中的user表,并创建了一个UserMapper接口来定义数据库操作方法。最后,在Main类中,我们通过MyBatis的API来执行这些方法,实现了对数据库的插入和查询操作。

通过以上实例,我们可以清晰地看到MyBatis如何简化数据库操作,使得开发者可以更加专注于业务逻辑的实现。

 

扫描下方二维码,一个老毕登免费为你解答更多软件开发疑问!

华为鸿蒙生态发展演讲:从操作系统到数字底座的进化论

【导语】在万物互联的智能时代,操作系统是数字世界的“地基”,而华为鸿蒙生态正以惊人的速度重构这一地基的形态。在2025华为开发者大会(HDC)上,华为消费者业务CEO余承东宣布:“鸿蒙生态已跨越1.5亿设备激活量,开发者数量突破380万,成为全球第三大移动应用生态。”这场演讲不仅揭示了鸿蒙的成长密码,更抛出了一个关键命题:当操作系统进化为数字底座,开发者将如何抓住下一波红利?一、数据透视:鸿蒙生态

百度发布多模态AI程序员Zulu:代码革命还是程序员“饭碗”终结者?

【导语】“让AI写代码,人类程序员该何去何从?”在2025百度AI开发者大会上,百度CTO王海峰抛出的这个问题,随着多模态AI程序员Zulu的发布被推向风口浪尖。这款号称“能听、能看、能思考”的代码生成工具,在内部测试中已实现82%的函数级代码自动生成,开发效率提升4倍。当AI开始入侵程序员最后的“技术护城河”,一场关于效率与饭碗的争论正在硅谷与中关村同步上演。一、技术解密:Zulu的“三头六臂”

苹果管理层大换血:库克押注AI机器人,能否再造“iPhone时刻”?

【导语】“当全球都在追赶Vision Pro时,苹果已经悄悄调转船头。”北京时间2025年4月29日,苹果官网悄然更新高管团队名单:原机器学习与AI战略高级副总裁John Giannandrea晋升为首席运营官(COO),机器人技术负责人Kevin Lynch进入执行董事会。这场被外媒称为“苹果20年来最大规模管理层调整”的变革,正式宣告库克将宝押向AI与机器人赛道。在这场豪赌背后,是苹果营收增速

腾讯云Craft智能体发布:AI开发进入“傻瓜模式”,中小企业迎来技术平权时代

【导语】“以后写代码就像发朋友圈一样简单。”在2025腾讯云峰会上,腾讯云副总裁吴运声抛出的这句话,随着全链路AI开发平台“Craft智能体”的发布引发行业震荡。这款被内部称为“AI开发界的美图秀秀”的产品,凭借“零代码搭建AI应用”“模块化自由组合”“按需付费”三大核心卖点,直击中小企业AI开发成本高、周期长、人才缺的行业痛点。当AI技术从实验室走向田间地头,Craft智能体能否成为企业智能化的

微信小程序

微信扫一扫体验

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部