MyBatis(入门)

入门MyBatis

什么是MyBatis?

MyBatis是一款用于持久层的、轻量级的半自动ORM(Object Relation Mapping)框架,封装了jdbc操作以及设置参数、查询参数和获取结果集的操作。

持久层的意思顾名思义就是"持久",他是将内存中的数据写到磁盘中的(数据库).

至于半自动的意思就是,他不能帮助我们写sql代码,需要手动配置各种映射关系,有自动就有全自动,hibernate就是一个全自动的ORM框架,而jdbc是"手动"的。

Mybatis用于处理java程序和数据库数据中间的交互,那为什么我们选用Mybatis呢?因为相比较于hibernate的全自动类型的框架,Mybatis显得更加灵活(因为sql是自己写的),而相比于jdbc的纯手动框架,Mybatis又显得更加解耦

下载MyBatis

我们需要进入GitHub的官网进行下载[:](MyBatis · GitHub)

我们下载这个Mybatis主要是为了得到Mybatis的使用手册

下载完成解压之后我们就呢得到MyBatis的jar包和使用手册

搭建MyBatis

开发环境

首先创建一个新项目

配置

这里的jdk版本一定要匹配

设置Maven

创建Maven工程

设置打包方式,以及注入依赖

xml 复制代码
<packaging>jar</packaging>

<dependencies>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.13</version>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.49</version>
    </dependency>
</dependencies>

创建MyBatis的核心配置文件

这个时候就需要用到我们下载的MyBatis使用手册了

复制代码
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="org/mybatis/example/BlogMapper.xml"/>
    </mappers>
</configuration>

配置连接数据库的环境

创建mapper接口

MyBatis中的mapper接口就相当于jdbc的dao,但是mapper仅仅是个接口,不需要提供实体类

我们先在对应的数据库中创建一张表

接着创建这张表对应的实体类并且加上有参和无参的构造方法、ge,set方法和对应的toString方法,属性必须和上方表对应

接着写这张表对应的mapper接口

创建mapper的映射文件

所谓MyBatis这种ORM(Object Relationship Mapper) 对象映射关系实际上就是

  • Object : Java实体类对象
  • Relationship :关系型数据库
  • Mapper : 两者之间的映射关系
Java 数据库
属性 字段
对象 记录

创建映射文件并加入对应的配置

复制代码
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.mybatis.example.BlogMapper">
<select id="selectBlog" resultType="Blog">
    select * from Blog where id = #{id}
</select>
</mapper>

现在我们要实现一个添加用户信息的功能

接着对映射文件进行编写,这里我们要主要MyBatis对应的两个一致,1.namespace要和mapper接口的全类名一致 2.映射文件SQL语句的id要和mapper接口中的方法名一致

最后引入映射文件

测试功能

首先创建对应的测试类

MyBatis为我们提供了一个操作数据库的会话对象SqlSession,有了SqlSession对象后我们就可以获取接口对象,从而进行测试功能的操作

运行显示影响行数为1,那么我们就测试添加成功了,这个时候数据库里并不会有这里添加的数据,如果想要将数据通过测试真正的添加进去那么要提交事务

这个时候查询数据库就添加上了用户信息

学到这里,已经是入门了MyBatis。

相关推荐
飞翔的佩奇21 分钟前
Java项目: 基于SpringBoot+mybatis+maven校园资料分享平台(含源码+数据库+答辩PPT+毕业论文)
java·spring boot·spring·毕业设计·maven·mybatis·校园资料分享平台
终末圆3 小时前
MyBatis 增删改查【后端 17】
java·服务器·数据库·b树·mysql·spring·mybatis
这孩子叫逆3 小时前
16. MyBatis的延迟加载机制是什么?如何配置?有哪些优缺点?
数据库·oracle·mybatis
捕风捉你3 小时前
MyBatis 源码解析:ResultHandler 设计与应用
java·mybatis
qq_3453370313 小时前
Mybatis通用接口-基于Provider
java·开发语言·mybatis
晚睡早起₍˄·͈༝·͈˄*₎◞ ̑̑16 小时前
Mybatis-plus进阶篇(二)
服务器·网络·mybatis
G皮T1 天前
【MyBatis】Java 数据持久层框架:认识 MyBatis
spring boot·spring·mybatis·框架·orm·dao
Fisher36521 天前
MyBatis-Plus分页查询、分组查询
mybatis
Ven%1 天前
mysql实用系列:日期格式化
数据库·mysql·mybatis
祁思妙想2 天前
《JavaEE进阶》----16.<Mybatis简介、操作步骤、相关配置>
java·java-ee·mybatis