博客
关于我
MyBatis(五):MyBatis简介及基本使用
阅读量:759 次
发布时间:2019-03-23

本文共 3813 字,大约阅读时间需要 12 分钟。

MyBatis入门及实践指南

MyBatis简介

MyBatis 是一款基于 ORM(对象关系映射)的半自动化持久层框架。它通过减少对 JDBC 的依赖,简化了数据库操作,使开发者能够专注于业务逻辑的实现,而非复杂的数据库连接和事务管理。MyBatis 支持定制化 SQL、存储过程以及高级映射功能,能够通过 XML 或注解配置数据库记录。

MyBatis 的优势

  • 半自动化:核心 SQL 仍需手动优化,但与 Java 编码分离,实现了“专注业务,专注数据”的理念。
  • 灵活性:支持多种数据库连接方式,便于在不同环境中使用。
  • 可扩展性:允许开发者根据项目需求自定义配置和行为。

MyBatis 的基本使用

1. 引入依赖

在项目中引入必要的依赖项,确保能够正常使用 MyBatis 和相关数据库连接。以下是示例配置:

mysql
mysql-connector-java
8.0.23
org.mybatis
mybatis
3.4.6
junit
junit
4.13.1

2. 编写实体类

定义实体类(POJO),将数据库中的数据与 Java 对象绑定。以下是一个典型的 User 实体类:

package com.rangers.entity;public class User {    private int id;    private String name;    private String address;    // setter 和 getter 方法(未展示)}

3. 编写核心配置文件 SqlMapConfig.xml

配置 MyBatis 的运行环境和数据源信息。以下是一个示例配置文件:

4. 编写接口方法及映射文件

定义接口并创建对应的映射文件(XML),实现数据库操作。以下是一个示例:

package com.rangers.dao;public interface IUserDao {    List
findAll(); User findOne(User user); int insertUser(User user); int updateUser(User user); int deleteUser(User user);}
insert into user(id, name, address) values/#{id}, #{name}, #{address}/
update user set name=#{name}, address=#{address} where id=#{id}
delete from user where id=#{id}

5. 编写测试类

通过单元测试验证 MyBatis 的功能是否正常。以下是一个测试类示例:

package com.rangers;import com.rangers.dao.IUserDao;import com.rangers.entity.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 org.junit.After;import org.junit.Before;import org.junit.Test;import java.io.IOException;import java.io.InputStream;import java.util.List;public class Test {    private IUserDao userDao;    private SqlSession sqlSession;    @Before    public void before() throws IOException {        InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);        sqlSession = sqlSessionFactory.openSession();        userDao = sqlSession.getMapper(IUserDao.class);    }    @Test    public void testFindAll() {        List
users = userDao.findAll(); System.out.println("所有用户信息:" + users); } @Test public void testFindOne() { User param = new User(); param.setId(1); User user = userDao.findOne(param); System.out.println("单个用户信息:" + user); } @Test public void testInsert() { User param = new User(); param.setId(3); param.setName("bug"); param.setAddress("北京"); boolean flag = userDao.insertUser(param) > 0; System.out.println("新增结果:" + flag); } @Test public void testUpdate() { User param = new User(); param.setId(3); param.setName("虫子"); param.setAddress("北京"); boolean flag = userDao.updateUser(param) > 0; System.out.println("修改结果:" + flag); } @Test public void testDelete() { User param = new User(); param.setId(3); boolean flag = userDao.deleteUser(param) > 0; System.out.println("删除结果:" + flag); } @After public void close() { System.out.println("关闭连接"); sqlSession.commit(); sqlSession.close(); }}

以上内容经过优化,结构清晰,语言流畅,易于阅读和理解,同时适合技术文档和教程使用。

转载地址:http://bwmzk.baihongyu.com/

你可能感兴趣的文章
Nginx配置参数中文说明
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nginx配置文件nginx.conf中文详解(总结)
查看>>
Nginx配置负载均衡到后台网关集群
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>