03-SpringBoot工程中MyBatis应用实践

创建项目moudle,名字为03-mybatis,其初始pom.xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns=“http://maven.apache.org/POM/4.0.0” xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”

xsi:schemaLocation=“http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd”>

4.0.0

org.springframework.boot

spring-boot-starter-parent

2.3.2.RELEASE

com.cy

03-mybatis

0.0.1-SNAPSHOT

03-mybatis

Demo project for Spring Boot

<java.version>1.8</java.version>

org.springframework.boot

spring-boot-starter

org.springframework.boot

spring-boot-starter-test

test

org.junit.vintage

junit-vintage-engine

org.springframework.boot

spring-boot-maven-plugin

添加项目依赖


mysql数据库驱动依赖,例如:

mysql

mysql-connector-java

runtime

添加mybatis依赖(参考官方),例如:

org.mybatis.spring.boot

mybatis-spring-boot-starter

2.1.3

我们添加了mybatis依赖以后,spring框架启动时会对mybatis进行自动配置。例如SqlSessionFactory工厂对象的创建。

Mybatis简易配置实现。


假如需要对mybatis框架进行简易配置,可以创建并打开application.properties文件,在此文件中进行基本配置(可选,暂时可以不配置),例如:

mybatis.configuration.default-statement-timeout=30

mybatis.configuration.map-underscore-to-camel-case=true

mybatis.mapper-locations=classpath:/mapper//.xml

配置mybatis中的sql日志的输出:(com.cy为我们写的项目的根包)

logging.level.com.cy=DEBUG

创建项目启动类


创建项目启动类,代码如下:

package com.cy;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication

public class MyBatisApplication {//Application.class

public static void main(String[] args) {//Main Thread

SpringApplication.run(MyBatisApplication .class, args);

}

}

环境测试代码实现


在src/test/java目录中添加测试类,对mybatis框架整合进行基本测试,代码如下:

package com.cy.pj.sys.dao;

@SpringBootTest

public class MyBatisTests {

@Autowired

private SqlSession sqlSession;

@Test

public void testGetConnection() {

Connection conn=sqlSession.getConnection();

System.out.println(“connection=”+conn);

}

}

在SpringBoot脚手架工程中,Spring框架会基于MyBatis框架底层配置,创建SqlSessionFactory对象,然后再通过此工厂对象创建SqlSession,最后基于Springku框架为测试类注入SqlSession对象,接下来,我们可以通过SqlSession对象实现与数据库的会话了。如图所示:

在这里插入图片描述

公告数据层MyBatis实践

========================================================================

业务描述


基于SpringBoot脚手架工程对MyBatis框架的整合,实现对通告数据的操作。

Pojo类设计


创建SysNotice类,借助此类对象封装公告(通知)数据。

package com.cy.pj.sys.pojo;

public class SysNotice {

/** 公告ID */

private Long id;

/** 公告标题 */

private String title;

/** 公告类型(1通知 2公告) */

private String type;

/** 公告内容 */

private String content;

/** 公告状态(0正常 1关闭) */

private String status;

/** 备注*/

private String remark;

/** 创建时间 */

private Date createdTime;

/** 修改时间*/

private Date modifiedTime;

/** 创建用户 */

private String createdUser;

/** 修改用户*/

private String modifiedUser;

//自己添加set/get/toString方法

}

Dao接口及方法


第一步:定义通告业务数据层接口及业务方法。借助此类型的对象基于MyBatis技术实现与数据库的交互。

package com.cy.pj.notice.dao;

@Mapper

public interface SysNoticeDao {

/**

  • 基于条件查询公告信息

  • @param notice 用于封装查询参数

  • @return 基于查询条件查询到结果

*/

List selectNotices(SysNotice notice);

/**

  • 基于id删除公告信息

  • @param id

  • @return 删除了几行

  • 说明:在jdk8之前,对于接口方法,假如参数有多个或者参数是数组,是不可以

  • 直接在sql映射文件中使用参数名的,需要通过@Param这个注解定义参数名,然后

  • 在sql映射语句中使用@Param注解中的名字获取参数数据。对于数组而言在sql映射

  • 中可以直接使用array进行接收也可以。

*/

int deleteById(@Param(“ids”) Long… id);//array

/**

  • 持久化notice对象数据

  • @param notice (封装了要写入的数据)

  • @return 返回写入的行数。

*/

int insertNotice(SysNotice notice);

/**

  • 基于id查询notice对象

  • @param id 公告唯一标识id

  • @return 基于id查询到结果

  • 建议:简单sql映射语句可以直接写到接口方法上,复杂sql还是推荐写到xml映射文件

*/

@Select(“select * from sys_notices where id=#{id}”)

SysNotice selectById(Long id);

/**

  • 持久化notice对象数据

  • @param notice (封装了要更新的数据)

  • @return 返回更新的行数。

*/

int updateNotice(SysNotice notice);

}

其中:@Mapper是由MyBatis框架中定义的一个描述数据层接口的的注解(所有的注解只起到一个描述性的作用),用于告诉Spring框架此接口的实现由mybatis创建,并将其实现类对象存储到spring容器。当系统启动时,会对启动类所在包以及子包中的类进行扫描,假如发现接口上有@Mapper注解(mybatis提供),系统底层会基于接口创建其实现类(借助反射包中Proxy类进行创建),在实现类的内部,底层会又基于sqlsession对象实现数据访问和操作。

第二步:创建SysNoticeDao接口对应的SQL映射文件,名字为SysNoticeMapper.xml,存储在resources/mapper/sys目录下,同时定义xml文件头以及根元素,代码如下:

<?xml version="1.0" encoding="UTF-8" ?>

第三步:在映射文件中添加insertNotice方法对应的Sql映射,关键代码如下:

insert into sys_notices

(title,type,content,status,remark,

createdTime,modifiedTime,createdUser,modifiedUser)

values

(#{title},#{type},#{content},#{status},#{remark},

now(),now(),#{createdUser},#{modifiedUser})

第四步:在映射文件中定义更新公告对应的SQL映射,关键代码如下:

update sys_notices

set title=#{title},

content=#{content},

type=#{type},

status=#{status},

remark=#{remark},

modifiedTime=now(),

modifiedUser=#{modifiedUser}

where id=#{id}

第五步:在映射文件中添加基于条件的SQL查询映射,关键代码如下:

<select id=“selectNotices”

parameterType=“com.cy.pj.sys.pojo.SysNotice”

resultType=“com.cy.pj.sys.pojo.SysNotice”>

select *

from sys_notices

type=#{type}

and title like concat(“%”,#{title},“%”)

and modifiedUser like concat(“%”,#{modifiedUser},“%”)

order by createdTime desc

第六步:在映射文件中定义删除操作对应的SQL映射,关键代码如下:

delete from sys_notices

id in

#{id}

or 1=2

单元测试实现及分析


第一步:在src/java/test目录下定义测试类,对NoticeDao对象进行应用测试。

package com.cy.pj.sys.dao;

@SpringBootTest

public class SysNoticeDaoTests {

必看视频!获取2024年最新Java开发全套学习资料 备注Java

总结

如果你选择了IT行业并坚定的走下去,这个方向肯定是没有一丝问题的,这是个高薪行业,但是高薪是凭自己的努力学习获取来的,这次我把P8大佬用过的一些学习笔记(pdf)都整理在本文中了

《Java中高级核心知识全面解析》

小米商场项目实战,别再担心面试没有实战项目:


第一步:在src/java/test目录下定义测试类,对NoticeDao对象进行应用测试。

package com.cy.pj.sys.dao;

@SpringBootTest

public class SysNoticeDaoTests {

必看视频!获取2024年最新Java开发全套学习资料 备注Java

总结

如果你选择了IT行业并坚定的走下去,这个方向肯定是没有一丝问题的,这是个高薪行业,但是高薪是凭自己的努力学习获取来的,这次我把P8大佬用过的一些学习笔记(pdf)都整理在本文中了

《Java中高级核心知识全面解析》

[外链图片转存中…(img-10dLqZ9R-1716376952346)]

小米商场项目实战,别再担心面试没有实战项目:

[外链图片转存中…(img-bphoL278-1716376952346)]

  • 18
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值