码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 「Spring Boot 系列」08. Spring Boot整合MyBatis


    在这里插入图片描述

    目录

    • Spring Boot整合MyBatis步骤:
      • 1. 新建Spring Boot工程,并选择需要使用的技术集
      • 2. 设置相关参数(数据源)
      • 3. 编写一个实体类 Person.java
      • 4. 定义数据层接口与映射配置(两种方式,任意一种都可)
      • 5. 测试类中注入dao接口,测试功能
      • 6. 运行结果

    Spring Boot整合MyBatis步骤:

    1. 新建Spring Boot工程,并选择需要使用的技术集

    在这里插入图片描述
    pom.xml文件

    
     
        org.mybatis.spring.boot
        mybatis-spring-boot-starter
        2.2.2
    
    
    
        mysql
        mysql-connector-java
        runtime
    
    
    
        org.springframework.boot
        spring-boot-starter-test
        test
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    2. 设置相关参数(数据源)

    application.yml

    #配置相关信息
    spring:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver  #com.mysql.jdbc.Driver该驱动类过时
        url: jdbc:mysql://localhost:3306/test?serverTimezone=UTC
        username: root
        password: root
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    3. 编写一个实体类 Person.java

    public class Person {
    
        private Integer id;
        private String name;
        private String city;
    
        public Integer getId() {
            return id;
        }
    
        public void setId(Integer id) {
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public String getCity() {
            return city;
        }
    
        public void setCity(String city) {
            this.city = city;
        }
    
        @Override
        public String toString() {
            return "Person{" +
                    "id=" + id +
                    ", name='" + name + ''' +
                    ", city='" + city + ''' +
                    '}';
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

    4. 定义数据层接口与映射配置(两种方式,任意一种都可)

    • 方式一:纯注解开发

      @Mapper //SQL映射添加@Mapper注解方便被容器识别
      public interface PersonDao {

      @Select("select * from person where id = #{id}")
      public Person getById(Integer id);
      
      • 1
      • 2

      }

    • 方式二:xml开发

    1. 新建一个PersonMapper接口

      @Mapper
      public interface PersonMapper {

      public List findAll();
      
      • 1

      }

    2. resources下新建一个mapper文件夹并在里面新建 PersonMapper.xml文件

      
      
      • 1
      • 2
      • 3
    3. 在application.yml 中添加MyBatis配置

      #MyBatis配置
      mybatis:
      mapper-locations: classpath:mapper/*Mapper.xml #mapper映射文件路径
      type-aliases-package: com.ityun.springbootstudy.domain #定义实体类的别名

    5. 测试类中注入dao接口,测试功能

    @SpringBootTest
    class SpringbootStudyApplicationTests {
    
        @Autowired
        private PersonDao personDao;
    
        @Autowired
        private PersonMapper personMapper;
    
        @Test
        public void findTest() {
            System.out.println(personDao.getById(1));
        }
    
        @Test
        public void findAllTest(){
            List list = personMapper.findAll();
            System.out.println(list);
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    6. 运行结果

    在这里插入图片描述在这里插入图片描述

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    c++ opencv库 Mat 使用(未完)
    抖音实战~发布短视频流程梳理
    微服务框架 SpringCloud微服务架构 11 自定义镜像 11.2 Dockerfile
    组里来了一个实习生,一行代码引发了一个惨案
    [C/C++]数据结构 深入挖掘环形链表问题
    核弹发射代码
    用友U8 cloud再升级,为成长型集团注入数智新力量
    Demo记录|移动端H5页面如何实现上下滑动触发事件的小功能
    并发编程永远绕不开的难题,跟着大牛带你Java并发编程从入门到精通
    OpManager Plus-IT基础设施监控
  • 原文地址:https://blog.csdn.net/m0_67400973/article/details/126080535
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号