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如何简化数据库操作,使得开发者可以更加专注于业务逻辑的实现。

 

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

物业管理工单AI调度方案:维修响应缩短至30分钟的核心算法

物业报修总是慢半拍?业主群里天天吐槽维修不及时?物业管理人员为工单分配焦头烂额?别慌!今天给大家揭秘一套超实用的物业工单 AI 调度方案,手把手教你用核心算法把维修响应时间从几小时压缩到 30 分钟内,让业主满意度直线飙升!​据中国物业管理协会发布的《2023 年物业管理行业发展报告》显示,在业主对物业的投诉中,维修响应不及时占比高达 38%。而当维修响应时间控制在 30 分钟以内时,业主对物业的

电商网站加速方案:WooCommerce加载从5s到0.9s的实操

你的 WooCommerce 电商网站是不是也总被用户吐槽 “加载慢如龟”?明明商品超有吸引力,却因为 5 秒的加载时间,白白流失了大量潜在客户!别慌!今天手把手教你把网站加载速度从 5 秒直接干到 0.9 秒,让你的店铺直接起飞!​根据 Akamai 的研究报告显示,网页加载时间每延迟 1 秒,就会导致用户转化率下降 7%,销售额降低 11% ,用户跳出率增加 16%。想象一下,每天几百上千的访

APP开发后如何做A/B测试? (转化率提升指南!界面/文案/按钮优化案例)

辛辛苦苦开发的 APP,转化率却总是上不去?根据麦肯锡发布的《2024 年移动应用用户行为报告》显示,经过科学 A/B 测试优化的 APP,平均转化率能提升 35%!想要让界面、文案、按钮成为转化 “利器”,A/B 测试绝对是必备技能。今天就通过真实案例,手把手教你用 A/B 测试提升 APP 转化率!一、为啥 A/B 测试是转化率的 “加速器”?用数据说话先看两组真实数据:某电商 APP 对商品

APP开发后如何做热更新? (动态修复BUG!不重新上架的更新方案)

APP 刚上线就发现严重 BUG,难道只能等重新上架 “干着急”?据 App Annie 发布的《2024 年移动应用质量报告》显示,因等待重新上架修复问题,平均每个 APP 会流失 12% 的用户。而热更新技术能让你绕过应用商店审核,动态修复 BUG!今天就手把手教你 APP 热更新的实现方案,让你的应用随时 “满血复活”。一、为啥热更新成了开发者的 “救命稻草”?先看一组真实数据:某热门游戏

微信小程序

微信扫一扫体验

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部