当前位置: 首页 > news >正文

java-Mybatis框架

简介

MyBatis 是一款优秀的持久层框架,它支持自定义 SQl、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

以上内容摘自于Mybatis中国官网

特点

①Mybatis 是一款优秀的持久层框架
②Mybatis 对 jdbc 进行封装, 简化了操作
③Mybatis 使用 xml 或注解方式, 将数据库记录映射到 java 对象中,
④是一种 orm(Object Relational Mapping 对象关系映射) 实现
⑤它支持动态 SQL 以及数据缓存.

mysql相关操作

-- 创建数据库 ssmdb
CREATE DATABASE ssmdb CHARSET utf8-- 创建表
-- 管理员表
CREATE TABLE admin(id INT PRIMARY KEY AUTO_INCREMENT,account VARCHAR(12) UNIQUE NOT NULL,`password` VARCHAR(32) NOT NULL,`name` VARCHAR(20) NOT NULL,gender CHAR(1)
)-- 添加测试用例
INSERT INTO admin (account, `password`, `name`, gender)
VALUES
('000000', '000000', 'JSON', '男'),
('000001', '000000', '张三', '男')-- 查询 admin 表中所有数据
SELECT * FROM admin

项目选择

创建Admin类 

package com.ffyc.mybatispro.modle;public class Admin {private int id;private String gender;private  String  password;private  String admin;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getAdmin() {return admin;}public void setAdmin(String admin) {this.admin = admin;}@Overridepublic String toString() {return "Admin{" +"id=" + id +", gender='" + gender + '\'' +", password='" + password + '\'' +", admin='" + admin + '\'' +'}';}
}

其中get, set方法不可缺, 底层会使用到

导入 MyBatis 和 mysql 的jar包

所需依赖,在 pom.xml 文件中完成配置即可

<dependencies><!-- MyBtais --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.2</version></dependency><!-- mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.16</version></dependency>
</dependencies>

创建 MyBatis 核心配置文件

在resources目录中创建一个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><settings><!-- 打印日志,添加此设置,会在运行时打印出此次操作的日志 --><setting name="logImpl" value="STDOUT_LOGGING"/></settings><typeAliases><!-- 指定到某一个目录下,如果没有此配置,需要在配置sql管理文件时,填入完整的类地址,
如:com.flash.mybatis.model.Admin --><package name="com.flash.mybatis.model"/></typeAliases><environments default="development"><environment id="development"><!-- 事物管理方式:就是一次对数据库操作过程中, 执行多条sql的管理转账:从A账户向B账户转钱A-500代码, 异常B+500把所有的操作都成功执行后, 再提交事务, 让数据库最终执行本次提交的所有sql--><transactionManager type="JDBC"/><!-- 使用jdbc事务管理 --><!-- 数据库链接池配置频繁的创建与校徽数据库的连接对象比较浪费时间,可以在池子中默认创建若干个连接对象, 有请求使用时, 直接从连接池中取出一个对象,用完还回去但不销毁, 减少了创建和销毁的时间开销如果连接个数不够用时仍然需要创建连接对象,数据库连接池中有一个下限和一个上线,默认最多为10,最少为5个--><dataSource type="POOLED"><!-- 数据库链接 --><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://127.0.0.1:3306/ssmdb?serverTimezone=Asia/Shanghai"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!-- 配置SQL管理文件 --><mappers><mapper resource="mappers/AdminMapper.xml"/></mappers>
</configuration>

创建与数据库交互所需的接口

package com.flash.mybatis.dao;import com.flash.mybatis.model.Admin;import java.util.List;// 定义功能
public interface AdminDao {/*根据id查询管理员对象*/Admin findAdminById(int id);List<Admin> findAdmins();int addAdmin(Admin admin);
}

创建xml文件管理sql

该文件内容如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.jorg//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.flash.mybatis.dao.AdminDao"><insert id="addAdmin" parameterType="Admin">INSERT INTO admin (account, `password`, `name`, gender)VALUE(#{account}, #{password}, #{name}, #{gender})</insert><!--id必须与方法名一致parameterType 接口中定义的方法所需要的参数类型resultType    查询结果返回类型#{account}    相当于调用 Admin 对象的 account 变量--><select id="findAdminById" parameterType="int" resultType="Admin">select * from admin where id = #{id}</select><select id="findAdmins" resultType="Admin">select * from admin</select>
</mapper>

测试类

import com.flash.mybatis.dao.AdminDao;
import com.flash.mybatis.model.Admin;
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.util.List;/*** @author flash* @date 2024/06/01 17:35* 功能描述:测试类*/
public class Test {public static void main(String[] args) throws IOException {// 读入 mybatis 核心配置文件Reader reader = Resources.getResourceAsReader("mybatis.xml");// 创建 SqlSessionFactory 对象// sqlSessionFactory 是用来创建 sqlSession的, 由于 sqlSessionFactory 对象创建的开销较大,// 所以一个项目只创建一个 sqlSessionFactory 对象, 不用关闭SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);// 创建SqlSession对象// sqlSession 对象与数据库交互的, 每次与数据库交互, 都需要一个新的连接对象// 用完关闭即可SqlSession sqlSession = sqlSessionFactory.openSession();// 为接口创建一个代理对象// 由代理对象调用接口中对应的方法AdminDao adminDao = sqlSession.getMapper(AdminDao.class);Admin admin = adminDao.findAdminById(1);System.out.println(admin);List<Admin> admins = adminDao.findAdmins();for (Admin admin1 : admins) {System.out.println(admin1);}admin = new Admin();admin.setAccount("000002");admin.setPassword("000000");admin.setName("李四");admin.setGender('女');System.out.println("count = " + adminDao.addAdmin(admin));sqlSession.commit();// 提交数据库事物, 事物只针对 增删改, 查询不需要提交事务// 关闭与数据库的会话对象sqlSession.close();}
}

sqlSession.commit();特别说明

如果对数据库进行查询操作,那么对数据库不会产生任何影响。如果是增删改操作,会对数据库中的数据进行一定改动。

        试想一种场景:A 给 B 转账 200 元,我们需要对数据库执行两部操作,A 中减去 200,B中增加 200,如果 两步中如有一步发生错误那么都会产生数据错误。解决方法,A 给 B 转账 200 元作为事件,java代码执行无误,将整个事件提交再来完成转账的操作,如果某一步发生错误将不会执行对应的sql语句。

        总结:由于查询操作不会对数据库数据产生影响,直接查询即可,不需要提交;如果是增删改操作,则需要将事务提交后参会执行对应的sql语句

 

简化测试

上面提到有些对象之需要创建一次, 那么我们就可以把他装入到一个工具类中来让我们每一次使用时直接调用即可, 但是由于要创建一个对象, 所以将他设置为静态对象, 并在static静态代码块中完成初始化, 见代码:

工具类

package com.flash.mybatis.util;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.Reader;/*** @author flash* @date 2024/06/01 17:32* 功能描述:*/
public class MybatisUtil {private static Reader reader;public static SqlSessionFactory sqlSessionFactory;static {// 读入 mybatis 核心配置文件try {reader = Resources.getResourceAsReader("mybatis.xml");} catch (IOException e) {e.printStackTrace();}// 创建 SqlSessionFactory 对象sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);}
}

测试类

import com.flash.mybatis.dao.AdminDao;
import com.flash.mybatis.model.Admin;
import com.flash.mybatis.util.MybatisUtil;
import org.apache.ibatis.session.SqlSession;import java.io.IOException;
import java.util.List;/*** @author flash* @date 2024/06/01 15:23* 功能描述:将一些重复的代码封装后使用的案例*/
public class Test2 {public static void main(String[] args) throws IOException {SqlSession sqlSession = MybatisUtil.sqlSessionFactory.openSession();// 为接口创建一个代理对象// 由代理对象调用接口中对应的方法AdminDao adminDao = sqlSession.getMapper(AdminDao.class);Admin admin = adminDao.findAdminById(1);System.out.println(admin);List<Admin> admins = adminDao.findAdmins();for (Admin admin1 : admins) {System.out.println(admin1);}admin = new Admin();admin.setAccount("000002");admin.setPassword("000000");admin.setName("李四");admin.setGender('女');adminDao.addAdmin(admin);sqlSession.commit();// 提交数据库事物, 事物只针对 增删改, 查询不需要提交事务// 关闭与数据库的会话对象sqlSession.close();}

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • MFC程序设计(一) MFC框架
  • 23种设计模式详细知识点(软件设计师)
  • 【工控】线扫相机小结
  • Linux编程:使用 CSV 与 UnQLite 进行数据存储的比较分析
  • Java中‘==’ 和 equals()的区别
  • GeoScene Pro教程(001):软件功能产品介绍
  • Win11配置Pytorch深度学习环境(GPU版本)
  • 鸿蒙HarmonyOS实战:IPC与RPC设备内进程通信
  • 【ROS2】launch启动文件:基础
  • pyyaml:Python 中的 YAML 处理大师
  • 【数学建模】TOPSIS法(优劣解距离法)
  • JimuReport 积木报表 v1.8.0 版本发布,开源可视化报表
  • fpga图像处理实战-图像旋转
  • ctfhub-web-整数型SQL注入
  • 网站上线流程完全手册:域名、服务器与CDN
  • 【140天】尚学堂高淇Java300集视频精华笔记(86-87)
  • 【Leetcode】104. 二叉树的最大深度
  • ES6--对象的扩展
  • IE报vuex requires a Promise polyfill in this browser问题解决
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • Web Storage相关
  • 订阅Forge Viewer所有的事件
  • 给初学者:JavaScript 中数组操作注意点
  • shell使用lftp连接ftp和sftp,并可以指定私钥
  • ​iOS安全加固方法及实现
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • ​二进制运算符:(与运算)、|(或运算)、~(取反运算)、^(异或运算)、位移运算符​
  • #define用法
  • #Linux(权限管理)
  • (22)C#传智:复习,多态虚方法抽象类接口,静态类,String与StringBuilder,集合泛型List与Dictionary,文件类,结构与类的区别
  • (3)nginx 配置(nginx.conf)
  • (C语言)输入一个序列,判断是否为奇偶交叉数
  • (el-Date-Picker)操作(不使用 ts):Element-plus 中 DatePicker 组件的使用及输出想要日期格式需求的解决过程
  • (附源码)计算机毕业设计ssm本地美食推荐平台
  • (转载)虚函数剖析
  • ./configure,make,make install的作用(转)
  • .net core + vue 搭建前后端分离的框架
  • .net core 6 集成和使用 mongodb
  • .NET Core IdentityServer4实战-开篇介绍与规划
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .NET Core日志内容详解,详解不同日志级别的区别和有关日志记录的实用工具和第三方库详解与示例
  • .net framwork4.6操作MySQL报错Character set ‘utf8mb3‘ is not supported 解决方法
  • .Net7 环境安装配置
  • .netcore 获取appsettings
  • .Net中的集合
  • .Net转前端开发-启航篇,如何定制博客园主题
  • /etc/fstab 只读无法修改的解决办法
  • @ConfigurationProperties注解对数据的自动封装
  • @Pointcut 使用
  • @RequestParam,@RequestBody和@PathVariable 区别
  • [ linux ] linux 命令英文全称及解释
  • [000-01-022].第03节:RabbitMQ环境搭建
  • [1159]adb判断手机屏幕状态并点亮屏幕
  • [5] CUDA线程调用与存储器架构
  • [ASP.NET 控件实作 Day7] 设定工具箱的控件图标