Mybatis【环境搭建】

news2025/3/1 16:12:11

目录

一、Maven 环境配置

1、配置 pom.xml

1.1、依赖的 jar包

1.2、防止资源导出失败

2、在resources下编写 Mybatis核心配置文件 

二、搭建结构

1、编写mybatis工具类(utils)

2、编写实体类(pojo)

3、Mybatis 的实现(dao层)

3.1、编写接口(UserMapper.java)

3.2、通过映射绑定并实现接口(UserMapper.xml)

三、测试

1、搭建数据库

2、编写测试类

3、运行结果


一、Maven 环境配置

1、配置 pom.xml

1.1、依赖的 jar包

<dependencies>
    <!--   mysql8 驱动,与本地mysql版本需要一致   -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.30</version>
        </dependency>
    <!--  mybatis  -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.2</version>
        </dependency>
    <!--  junit,测试工具   -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
    </dependencies>

1.2、防止资源导出失败

<build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>

2、在resources下编写 Mybatis核心配置文件 

命名为mybatis-config.xml,作用是连接数据库

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//OTD Config 3.0//EN"
        "http://mybatis.org/schema/mybatis-3-config.dtd">
<!-- 核心配置文件 -->
<configuration>
        <environments default="development">
            <environment id="development">
                <transactionManager type="JDBC"/>
                <dataSource type="POOLED">
                    <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                    <!--防止乱码 中文出现?-->
                    <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/>
                    <property name="username" value="root"/>
                    <property name="password" value="******"/>
                </dataSource>
            </environment>
        </environments>
</configuration>

二、搭建结构

1、编写mybatis工具类(utils)

作用是获取SqlSession对象,相当于JDBC中的 Statement对象

package com.study.utils;

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.InputStream;

public class MybatisUtils {

    private static SqlSessionFactory sqlSessionFactory;

    static {
        try {
            //1.获取sqlSessionFactory对象
            String resource = "mybatis-config.xml";//maven项目下路径这么写
            InputStream inputStream = Resources.getResourceAsStream(resource);
            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    //SqlSessionFactory 顾名思义,我们可以通过工厂创建SqlSession对象
    //SqlSession 完全包含了面向数据库执行 SQL 命令所需的所有方法
    public static SqlSession getSqlSession(){
        return sqlSessionFactory.openSession();
    }
}

2、编写实体类(pojo)

实现所有 get和set 方法并重写 toString方法

package com.study.pojo;

public class User {
    //全部按着数据库来,名字一一对应
    private int id;
    private String name;
    private String pwd;

    public User(){
    }

    public User(int id, String name, String pwd) {
        this.id = id;
        this.name = name;
        this.pwd = pwd;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPwd() {
        return pwd;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
    }
    
    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", pwd='" + pwd + '\'' +
                '}';
    }
}

3、Mybatis 的实现(dao层)

以添加用户为例

3.1、编写接口(UserMapper.java)

接口的实现在映射文件(UserMapper.xml)中实现

public interface UserMapper {
    int addUser(User user);
}

3.2、通过映射绑定并实现接口(UserMapper.xml)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//OTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.study.dao.UserMapper">
    <insert id="addUser" parameterType="com.study.pojo.User">
        insert into mybatis.user (id,name,pwd)
        values (#{id},#{name},#{pwd});
    </insert>
</mapper>

三、测试

1、搭建数据库

create table user (
    id int(20) not null,
    name varchar(30)default null,
    pwd varchar(30) default null,
    primary key(id)
) engine=innodb default charset=utf8;

 

2、编写测试类

注意:增删改需要提交事务 , 查询语句不需要

 Mybatis 操作数据库和 JDBC 比较相似但 Mybatis更加简单便捷!

@Test
    public void updateUser(){
        //1.获取数据库操作对象
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //2.获取接口
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        //3.执行SQL语句
        User user = new User(1,"燕双鹰","123456");
        mapper.addUser(user);

        //4.提交事务
        sqlSession.commit();

        //5.关闭资源
        sqlSession.close();
    }

3、运行结果

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

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

相关文章

一篇搞定Lambda和Stream流

一、Lambda表达式 jdk8中的语法糖&#xff0c;优化某些匿名内部类的写法&#xff0c;函数式编程的重要体现&#xff0c;不再关注对象是什么&#xff0c;更关注数据进行了什么操作 1、练习 练习1 练习2 练习3 练习4 练习5 2、省略规则 参数类型可以省略方法体只有一句代码时…

【Leetcode】消失的数字 [C语言实现]

&#x1f47b;内容专栏&#xff1a;《Leetcode刷题专栏》 &#x1f428;本文概括&#xff1a; 面试17.04.消失的数字 &#x1f43c;本文作者&#xff1a;花 碟 &#x1f438;发布时间&#xff1a;2023.4.10 目录 思想1&#xff1a;先排序再查找 思想2&#xff1a;异或运算 代…

TensorFlow 图像深度学习实用指南:1~3 全

原文&#xff1a;Hands-On Deep Learning for Images with TensorFlow 协议&#xff1a;CC BY-NC-SA 4.0 译者&#xff1a;飞龙 本文来自【ApacheCN 深度学习 译文集】&#xff0c;采用译后编辑&#xff08;MTPE&#xff09;流程来尽可能提升效率。 不要担心自己的形象&#xf…

移动版OpenAI,手机的杀手还是救星?

AI登陆手机&#xff0c;难度因人而异。 原本小编还以为「2023年是属于元宇宙的一年」&#xff0c;实在没想到以ChatGPT为代表的AI技术能在这么短的时间内抢走元宇宙的风头&#xff0c;成为2023年的技术关键词。从OpenAI到搜索引擎、从绘图工具到游戏公司&#xff0c;几乎所有「…

跨境电商的行业现状与发展趋势分析

随着互联网的不断发展&#xff0c;跨境电商作为一种全新的商业模式已经逐渐崭露头角。跨境电商的出现&#xff0c;让越来越多的商家看到了扩大市场的机会&#xff0c;也为消费者提供了更加便利、更加优质的购物体验。本文将从跨境电商的定义、行业现状、发展趋势等方面进行探讨…

windows下的wsl2如何进行docker数据卷挂载

这是数据卷挂载命令 docker run -it -v /宿主机绝对路径目录: /容器内目录 镜像名 在Linux中我们可以直接使用该命令进行挂载&#xff0c;那在windows如何把我们c盘d盘下的目录挂载到容器呢&#xff0c;其实只要在路径前面加上/mnt就好了&#xff0c;下面来演示一下 首先拉取一…

About RadaeePDF Classic SDK for iOS Crack

About RadaeePDF Classic SDK for iOS Crack RadaeePDF iOS版经典SDK可帮助您构建更好的移动应用程序。使用功能强大的PDF阅读器引擎及其一系列专业功能现在是一个快速而简单的过程。适用于iOS的RadaeePDF Classic SDK在智能手机、平板电脑、笔记本电脑、敞篷车和台式机上提供了…

运行时内存数据区之方法区(一)

方法区 栈、堆、方法区的交互关系 方法区的理解 oracle官网上的描述&#xff1a; 《Java虚拟机规范》中明确说明&#xff1a;“尽管所有的方法区在逻辑上是属于堆的一部分&#xff0c;但一些简单的实现可能不会选择去进行拉圾收集或者进行压缩。”但对于HotspotJVM而言&#x…

“影视级”直播呈现,保利威1号演播厅与企业共建行业直播新标准 | 爱分析调研

前言&#xff1a;3月22日&#xff0c;保利威举办了2023春季线上发布会&#xff0c;推出首个企业级直播基地——“1号演播厅”。会上重磅发布了《2023中国企业直播应用标准》并启动“企业直播运营官千英计划”&#xff0c;开启企业直播历史性新篇章。 01 企业直播迈入3.0阶段 …

AB91-1 HESG437479R1 HESG437899

AB91-1 HESG437479R1 HESG437899 以硅为基材的集成电路共有Si BJT(Si-Bipolar Junction Transistor)、Si CMOS、与结合Bipolar与CMOS 特性的Si BiCMOS(Si Bipolar Complementary Metal Oxide Semiconductor)等类。由于硅是当前半导体产业应用最为成熟的材料&#xff0c;因此&am…

Linux基础篇(四)打包和解压

目录 一、打包和压缩 二、zip 和 unzip 三、tar指令 一、打包和压缩 1.是什么&#xff1f; 打包&#xff1a;将东西放到一起。 压缩&#xff1a;采用某种压缩算法&#xff0c;压缩它的存储空间。 2.为什么&#xff1f; 便于传输&#xff0c;或者归档&a…

【pygame游戏开发】这几个经典游戏,勾起了少年的快乐

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 今天给大家分享几个好玩有趣的小游戏&#xff0c; 既提升了学习的兴趣&#xff0c;又提升了学习效率&#xff0c;告别枯燥的学习。 代码软件: python 3.8: 解释器 pycharm: 代码编辑器 一、飞机大战 1. 所需素材 …

大气颗粒物PMF源解析实践技术应用

查看原文>>>【案例实践】大气颗粒物PMF源解析实践技术应用 目录 第一章、PMF源解析技术简要及其输入文件准备 第二章、PMF源解析技术的原理&#xff0c;PMF软件的实操及应用举例 第三章、PMF源解析结果的优化及误差评估 其它大气环境相关推荐 目前&#xff0c;大…

纯跟踪算法(Pure persuit)

纯跟踪局部路径规划器 在得到局部路径之后&#xff0c;本项目使用纯跟踪算法通过横向控制器反馈控制小车的转角&#xff0c;从而达到跟踪局部路径的效果&#xff0c;经实验确认&#xff0c;跟踪效果很好。 纯跟踪算法原理如下&#xff1a; 在搭建模型时可以将小车看作车辆运…

MySQL 8.0原理与实战一网打尽,甲骨文数据库专家硬刚5年之作

根据权威数据库技术排名网站DB-Engines今年4月的最新数据&#xff0c;MySQL是全球最流行的开源数据库&#xff0c;没有之一。在所有数据库排名中&#xff0c;MySQL仅次于Oracle&#xff0c;“屈居”亚军之位。但大家从截图中可以看出&#xff0c;MySQL与Oracle的得分差距已经非…

【C语言】分支语句和循环语句(上)

【C语言】分支语句和循环语句&#xff08;上&#xff09;前言1.分支语句和循环语句2.什么是语句3.分支语句&#xff08;选择语句&#xff09;3.1 if语句3.1.1 悬置else3.1.2 if的书写形式对比3.1.3 在线练习3.2 switch语句3.2.1 switch语句中的break的作用3.2.2 default子句3.2…

记一次csdn图片访问失败问题

前言 家里电脑写博客 一直图片查看不了 以为csdn问题 后来发现可能是网络的问题 公司电脑访问都是正常的&#xff0c;并且换个浏览器也是一样 记录一下排查过程 过程 法1 chrome 关闭对csdn不安全访问 回归一下 可能要找img-blog.csdnimg.cn这个地址的试一下 法2 换dns …

Linux:centos 关闭 防火墙 关闭SELinux 配置临时ip

1.关闭防火墙 systemctl status firewalld.service 查看防火墙状态 这个是运行中&#xff0c;使用 systemctl stop firewalld.service 临时关闭防火墙 这个样子的话重启之后就会再次自动开启防火墙 systemctl disable firewalld.service 永久关闭防火墙 然后重启centos 可以看…

【Python实战】2022年中国富豪榜出炉,首富竟是他......教你一键采集榜单并做可视化效果图(今天是拉仇恨的一天鸭~)

前言 哈喽&#xff0c;我是你们的栗子同学~ 今天是拉仇恨的一天&#xff1a; 教大家一键采集&#xff08;爬虫数据分析基础实战&#xff09;新CaiFu中国500富人榜&#xff0c;中国首富竟然是他...... 所有文章完整的素材源码都在&#x1f447;&#x1f447; 粉丝白嫖源码福利…

深度学习入门之感知机

一. 感知机的定义 感知机接收多个输入信号&#xff0c;输出一个信号。这里所说的“信号”可以想象成电流或河流那样具备“流动性”的东西。像电流流过导线&#xff0c;向前方输送电子一样&#xff0c;感知机的信号也会形成流&#xff0c;向前方输送信息。但是&#xff0c;和实…