【MyBatis】第一篇:初体验

news2025/1/21 13:56:17

还是老规矩看一下百度百科中的解释:

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。

听着很迷糊,看着文字也迷糊。不过这个这个适合有一个疑问了,mybatis既然是一个框架,那么其与jdbc有什么区别呢?不多是链接数据库吗?

其实mybatis是对jdbc的依次再包装,有点像是工具库类commons-dbutils的升级,然而其可以通过配置文件和映射来方便我们操作数据库。

其实这些都是理论是迷糊的,还是老规矩直接用实例进行简单演示。

前提

因为采用的maven进行的实例演示,所以需要对IDE中创建maven显目,以及maven是什么需要简单的了解,这个可以看我写的关于maven了解的基础文章。

而下面进行配置的适合通过修改pom.xml进行环境依赖。当然如果不想这样,还是喜欢下载jar包,然后进行配置也行。

  • 导入mysql的java驱动包。毕竟连接数据库,无论使用什么框架都需要有这个基础。

    根据自己的数据库版本,进行配置。

    因为安装的mysq5.0版本,所以驱动也是对应的,这个需要再pom.xml中配置

    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.37</version>
    </dependency>
    
  • 导入mybatis的依赖包

    <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.4.6</version>
    </dependency>
    
    
  • 在mysql中创建数据库以及表。

    CREATE DATABASE  `testmybatis`  ;
    USE `testmybatis`;
    DROP TABLE IF EXISTS `student`;
    CREATE TABLE `student` (
      `SNAME` varchar(10) default NULL,
      `SAGE` int(3) default NULL,
      `SSEX` varchar(2) default NULL
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    INSERT INTO testmybatis.student (SNAME, SAGE, SSEX)VALUES('张三', '17', '男');
    

环境进行配置,然后下面进行简单演示。

实例演示

配置文件

核心配置文件

核心配置文件一般也是一个xml,其习惯命名为mybatis-config.xml。而这个文件名如果项目有其它名字,也可以。在后面和spring进行整合的话,配置文件可以省略的。

核心配置文件的具体作用是配置连接环境以及mybatis的全局配置信息。

因为我使用的maven创建的项目,所以配置文件在:

在这里插入图片描述

其具体简单格式如下:

<?xml version="1.0" encoding="utf-8"?>
<!--配置文件中可以使用哪些标签,这个地方是配置这是一个mybatis文件,使用mybatis文件标签-->
<!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.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/testmybatis"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
<!--        <mapper resource="映射文件这个地方配置sql语句,后面具体演示"></mapper>-->
        
        <mapper resource="mappers/StudentMapper.xml"></mapper>
    </mappers>
</configuration>

其实这个配置信息,具体配置是什么作用就行,如果非要记住也可以,也可以黏贴复制使用。

操作的mapper接口类

前面核心配置文件说需要导入映射文件,这个对用的之前聊的DAO,也就是对数据库进行操作的类,其实又有不同的地方,每个mapper的类都是接口也仅仅接口,不需要具体实现的类。虽然类不需要但是其需要的是mapper配置的文件。

具体的mapper接口内容:

package com.xzd.mapper;

public interface StudentMapper {
    int insertStudent();
}

创建mybatis映射(mapper)文件

补充概念-----ORM

ORM其全英文是Object Relationship Mapper, 其意思是一种对象关系映射。

  • 对象(Object):java实体类对象。
  • 关系(Relationship): 关系型数据库
  • 映射(Mapper): 二者之间的对应关系。

其实Java终端一些概念和数据库中的概念,在映射的时候如下:

java概念数据库概念
属性字段
对象某行记录
映射文件

映射文件也是一个xml,前面说了mapper类只是接口没有实现类,但是具体的一些对数据库操作的sql却似写在映射文件中的。

但是这个时候又有一些规则:

  • 映射文件的命名规则

    数据库中对应的实体类的类名+Mapper.xml, 比如我的例子中数据库表student,但是其对应的类是Student,所以配置映射文件为StudentMapper.xml。

  • 这里又有两个一致

    • 其实为了方便在写映射类(StudentMapper.java)的时候两者名字一样,只是后缀不一样。
    • 映射类(StudentMapper.java)中的方法,和映射文件中的id一直保持一致。这个说话有点绕,具体看配置文件可知。

配置文件:

<?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.xzd.mapper.StudentMapper">
<!--    这个配置文件id和 mapper类中的方法一样-->
    <insert id="insertStudent">
        INSERT INTO testmybatis.student VALUES('赛貂蝉', '15', '女')
    </insert>

</mapper>

测试类

这个就直接写测试类,是官网文档的api的使用:

package com.xzd.test;

import com.xzd.mapper.StudentMapper;
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.Test;
import java.io.IOException;
import java.io.InputStream;

public class Test_mabtis {
    @Test
    public void test1() throws IOException {
//         通过IO操作配置文件  所以说这个配置文件可以改名字,一般默认是mybatis-config.xml
        InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
//        SqlSession类似与jdb中connection,但是其通过SqlSession工厂而创建的,而这个工厂却是通过工厂的构造类SqlSessionFactoryBuilder得到工厂
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//        返回SqlSessionFactory
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);
//        得到SqlSession
        SqlSession sqlSession = sqlSessionFactory.openSession();
        
        
        
//        这个通过代理模式,传入什么类返回什么类
        StudentMapper studentMapper = sqlSession.getMapper(StudentMapper.class);
//         这个回执行映射文件中的插入语句
        int result = studentMapper.insertStudent();
        //         上面两句其实可以合成一句来实现
//        这个参数就是直接将<mapper namespace="com.xzd.mapper.StudentMapper"> 和<insert id="insertStudent">结合起来
 //        int result1 =  sqlSession.insert("com.xzd.mapper.StudentMapper.insertStudent");
        
        
        
        
        System.out.println(result);
//        默认事务是打开的,所以需要提交
        sqlSession.commit();
//        关闭sqlSession
        sqlSession.close();
    }
}


然后执行可以插件数据库:

在这里插入图片描述

补充

先不说传递参数问题先让sql语句定死。增删改在定死的时候差不多,需要在配配置文件上进行设置返回类型:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-H4qjbVS4-1673268828283)(F:\文档\笔记\java\MyBatis\1:mybatis简介.assets\image-20230109205203435.png)]

例子伪代码

<?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.xzd.mapper.StudentMapper">
    <!--    这个配置文件id和 mapper类中的方法一样-->
    <insert id="insertStudent">
        INSERT INTO testmybatis.student
        VALUES ('赛貂蝉', '15', '女')
    </insert>
    <select id="getStudent" resultType="com.xzd.domain.Student">
        SELECT 	* FROM  testmybatis.student  WHERE SNAME='张三'
    </select>

    <select id="getAllStudent" resultType="com.xzd.domain.Student">
        SELECT 	* FROM  testmybatis.student
    </select>
 
</mapper>
package com.xzd.mapper;

import com.xzd.domain.Student;

import java.util.List;

public interface StudentMapper {
    int insertStudent();
    Student getStudent();
    List<Student> getAllStudent();

}

调用代码一样,就不再演示了,直接看结果了。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/151716.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Web(三)

JavaScript基础概念&#xff1a;一门客户端脚本语言* 运行在客户端浏览器中的。每一个浏览器都有JavaScript的解析引擎* 脚本语言&#xff1a;不需要编译&#xff0c;直接就可以被浏览器解析执行了功能&#xff1a;* 可以来增强用户和html页面的交互过程&#xff0c;可以来控制…

蓝桥杯C51

#include "reg52.h"sfr AUXR 0x8e; //定义辅助寄存器sbit S5 P3^2; //定义按键S5引脚 sbit S4 P3^3; //定义按键S4引脚unsigned char count 0; //定义中断计数器 unsigned char t_h 0; //定义运行时间的变量 unsigned char t_m 0; …

Struts2之OGNL表达式

Struts2之OGNL表达式1、什么是OGNL表达式2、OGNL表达式的作用3、值栈与OGNL3.1、值栈3.2、OGNL访问值栈4、类型转换4.1、类型转换的意义4.2、内置的类型转换器4.3、自定义类型转换器4.3.1、创建日期转换器4.3.2、配置转换器4.3.3、页面4.3.4、实体类和Action控制器4.3.5、strut…

从0到1完成一个Vue后台管理项目(七、Header、Footer、页面布局)

往期 从0到1完成一个Vue后台管理项目&#xff08;一、创建项目&#xff09; 从0到1完成一个Vue后台管理项目&#xff08;二、使用element-ui&#xff09; 从0到1完成一个Vue后台管理项目&#xff08;三、使用SCSS/LESS&#xff0c;安装图标库&#xff09; 从0到1完成一个Vu…

2010-2020年和讯网分行业社会责任指数

2010-2020年和讯网分行业社会责任指数 1、时间&#xff1a;2010-2020年 2、行业包括&#xff1a; 银行业&#xff08;III&#xff09;、人寿保险&#xff08;III&#xff09;、普通金融服务、工业运输、采矿业、饮料、不动产、食品与药品零售、电力&#xff08;III&#xff…

JS字符串的截取出现的bug

前言 在js中我们对字符串进行一部分截取&#xff0c;可以使用slice()函数截取&#xff0c;也可以直接用substring()函数来截取&#xff0c;但是截取也有可能出bug const str小&#x20bb7;和小&#x27a01;今天吃了50块钱的KFC console.log(str.slice(0,5)); 可以在控制台看…

ESP-IDF:数组为空异常处理例程

1.需要开启对ESP-IDF 中的 C 异常的支持。 默认情况下禁用对 ESP-IDF 中的 C 异常的支持,但可以使用 CONFIG_CXX_EXCEPTIONS 选项启用. 如果禁用对 ESP-IDF中的 C 异常的支持这样编译例程会报错&#xff1a; error: exception handling disabled, use -fexceptions to enable…

node.js中的文件读取写入操作

fs文件系统模块 什么是fs文件系统模块 fs模块是node.js官方提供的、操作文件的模块。通过fs模块可以实现对文件的读取以及写入操作。 例如&#xff1a; fs.readFile():用于读取指定文件的文件内容fs.writeFile()&#xff1a;用于向指定的文件写入内容 引入fs模块&#xff…

[2023] NAND闪存及控制器的市场趋势

一、NAND闪存市场分析据欧洲知名半导体分析机构Yole发布的报告显示&#xff0c;2020年起&#xff0c;NAND闪存市场发展趋势保持稳定增长&#xff0c;2021年&#xff0c;NAND闪存市场份额达到了近670亿美元&#xff08;见图1&#xff09;&#xff0c;同年&#xff0c;NAND闪存总…

使用 Vagrant 对 VirtualBox 虚拟机磁盘扩容

使用Vagrant 对 VirtualBox 磁盘扩容 Vagrant 下载地址: https://www.vagrantup.com/downloads.html Vagrant版本 2.3.4 VirtualBox版本&#xff1a;7.0.4 1、在初次使用 Vagrant init 创建 VirtualBox 虚拟机时&#xff0c;会创建一个 Vagrantfile 文件 2、在 Vagrantfile…

CAS:60842-46-8;葡聚糖-荧光素;Dextran-FITC

Dextran-FITC、葡聚糖-荧光素、&#xff08;葡聚糖-FITC&#xff09; CAS NO: 60842-46-8 英文名称&#xff1a;&#xff1a; Dextran(3,6dihydroxy-3-oxospiro(isobenzofuran-1(3H],9-[9H]xanthen]-5(or 6]-yl]carbamothioate, average Mw of approximately 分子量&#xf…

java 微服务之docker基础入门 docker部署 镜像相关命令 容器命令 数据卷 DockerCompose Docker镜像仓库

初识Docker 项目部署的问题 什么是Docker 不同环境的操作系统不同&#xff0c;Docker如何解决&#xff1f;我们先来了解下操作系统结构 Docker与虚拟机 虚拟机是在一个系统内&#xff0c;运行另外一个系统 镜像和容器 镜像&#xff08;Image&#xff09;&#xff1a;Docker将…

基于STM32 STC15和SU-03T离线语音模块的智能语音自拍器设计

一. 系统设计及框图 现在的自拍系统有很多是蓝牙控制的&#xff0c;我们这次介绍的是使用语音控制的拍照系统。 本系统通过MCU产生20kHZ左右的频率驱动蜂鸣器&#xff08;占空比为50%即可&#xff09;&#xff0c;手机APP收到此特定频率的信号后会执行相应的拍照或切换镜头的…

Spring 响应式编程,真香!!!

一、前言 响应式编程是啥&#xff1f;为啥要有响应式编程&#xff1f;响应式流的核心机制是什么&#xff1f;Spring 响应式编程能解决我们平时开发的什么痛点&#xff1f;Spring 响应式编程有哪些应用场景&#xff1f;Spring 响应式编程未来的趋势如何&#xff1f; 开篇六连问…

必要条件和充分条件与分析问题的方法

作为一名软件工程师&#xff0c;大部分的工作时间都是在解决各种问题中度过的&#xff0c;相信大部分的工程师都有类似的感受。这些问题发生在不同的技术领域&#xff0c;不同的技术方向&#xff0c;不同的模块&#xff0c;甚至不同的环境下&#xff0c;不一而足&#xff0c;就…

韩顺平老师的Linux基础学习笔记 (下)

Linux学习笔记 前言&#xff1a;本系列笔记的参考由 2021韩顺平 一周学会Linux 总结而成&#xff0c;希望能给学习Linux的同学一些帮助。也感谢韩老师录制的视频给我带来了非常巨大的收获&#xff01; 目录&#xff1a; 韩顺平老师的Linux基础学习笔记 (上)韩顺平老师的Linu…

swagger2 介绍+注解说明

简介: 为什么要用swagger&#xff0c;我的理由是方便&#xff0c;作为后端开放人员&#xff0c;最烦的事就是自己写接口文档和前端交互是不是需要各种参数很繁琐&#xff0c;项目集成swagger后就能自动生成接口文档&#xff0c;做到前端、后端联调接口文档的及时性和便利性。 …

Eureka与Nacos的区别

Eureka 工作原理图 Nacos工作原理图 Eureka与Nacos相同点 都支持服务注册和服务拉取。 都支持服务提供者心跳方式做健康检测。 Eureka与Nacos区别 Nacos支持服务端主动检测提供者状态&#xff1a;临时实例采用心跳模式&#xff0c;非临时实例采用主动检测模式 临时实例心跳…

理解Java的线程安全问题

目录 目录 举例&#xff1a;三个窗口卖票 运行结果&#xff1a;出现重票 如何解决&#xff1f; 方式一&#xff1a;同步代码块&#xff0c;第一个例子 运行结果&#xff1a; 改进&#xff1a; 运行结果&#xff1a; 方法一&#xff1a;同步代码块的第二个例子。把锁和ti…

使用opencv进行脸部识别

1.读取人脸部图片 引入需要的库&#xff0c;并读取人脸的图片 import cv2 import matplotlib.pyplot as plt import numpy as np# 定义t2s函数&#xff0c;方便查看是否对图片进行RGB通道转换 def t2s(img):return cv2.cvtColor(img, cv2.COLOR_BGR2RGB)# 读取图片 img cv2.…