【MyBatis】快速入门

1、简介

MyBatis是一个持久化、轻量级的半自动化ORM框架,封装了所有JDBC的原始操作。查询参数以及获取结果集等。

1.1 原始JDBC操作存在的问题

(1)数据库连接、释放频繁造成系统资源浪费,影响系统性能

(2)SQL语句在代码中固定,不够灵活不易改动

(3)进行查询操作时,需要手动将结果集封装到实体类中。进行插入操作时,需要手动将

参数设置到占符位置

1.2 解决方案

(1)使用数据库连接池初始化连接资源

(2)将SQL语句抽取到xml配置文件中

(3)使用反射、内省等底层技术,将实体类的属性与表中的字段进行自动映射

2、快速构建

1、添加MyBatis坐标以及数据库连接驱动

java 复制代码
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.6</version>
        </dependency>

        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <version>8.0.31</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
            <scope>test</scope>
        </dependency>

2、编写MyBatis核心配置文件sqlMapConfig.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="dev">
        <environment id="dev">
            <transactionManager type="JDBC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/eshop"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>

    <mappers>
        <mapper resource="mapper/UserMapper.xml"></mapper>
    </mappers>

</configuration>

3、编写MyBatis映射文件UserMapper.xml

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="userMapper">
    <select id="findAll" resultType="com.wn.mybatis.pojo.User">
        select * from t_user
    </select>
</mapper>

4、创建实体类与数据库表

相关推荐
一叶之秋14121 分钟前
千面之法: 释放 C++ 多态的灵活威力
开发语言·c++
柒.梧.2 分钟前
Java拷贝精讲:彻底分清浅拷贝与深拷贝
java·开发语言·python
七夜zippoe5 分钟前
微服务架构下Spring Session与Redis分布式会话实战全解析
java·redis·maven·spring session·分布式会话
一晌小贪欢5 分钟前
PyQt5 实战:批量图片添加水印工具(带右侧实时预览)(附代码及下载链接)
开发语言·qt·添加水印·图片添加水印·蹄片水印
超绝振刀怪7 分钟前
【C++ vector】
开发语言·c++
机器视觉的发动机9 分钟前
图像处理-机器视觉算法中的数学基础
开发语言·人工智能·算法·决策树·机器学习·视觉检测·机器视觉
guohahaya10 分钟前
attention-2026
开发语言·c#
vx_Biye_Design2 小时前
【关注可免费领取源码】云计算及其应用网络教学系统--毕设附源码35183
java·spring·spring cloud·servlet·eclipse·云计算·课程设计
lntu_ling3 小时前
Python-基于Haversine公式计算两点距离
开发语言·python·gis算法
ShineWinsu8 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承