详解SpringBoot 快速整合MyBatis(去XML化)

网友投稿 290 2023-03-27


详解SpringBoot 快速整合MyBatis(去XML化)

序言:

此前,我们主要通过XML来书写SQL和填补对象映射关系。在SpringBoot中我们可以通过注解来快速编写SQL并实现数据访问。(仅需配置:mybatis.configuration.map-underscore-to-camel-case=true)。为了方便大家,本案例提供较完整的层次逻辑SpringBoot+MyBatis+Annotation。

具体步骤

1. 引入依赖

在pom.xml 引入ORM框架(Mybaits-Starter)和数据库驱动(mysql-Conn)的依赖。

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

org.springframework.boot

spring-boot-starter-parent

2.0.0.M4

&uzRDIlt;dependency>

org.springframework.boot

spring-boot-starter-web

org.mybatis.spring.boot

mybatis-spring-boot-starter

1.3.1

mysql

mysql-connector-java

runtime

org.springframework.boot

spring-boot-starter-test

test

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

org.springframework.boot

spring-boot-starter-parent

2.0.0.M4

&uzRDIlt;dependency>

org.springframework.boot

spring-boot-starter-web

org.mybatis.spring.boot

mybatis-spring-boot-starter

1.3.1

mysql

mysql-connector-java

runtime

org.springframework.boot

spring-boot-starter-test

test

2. 添加数据源

在application.yml 添加数据源,以及开启Mybaits的驼峰映射功能。

spring:

datasource:

url: jdbc:mysql://localhost:3306/socks?useSSL=false

username: root

password: root

driver-class-name: com.mysql.jdbc.Driver

mybatis:

configuration:

map-underscore-to-camel-case: true #开启驼峰映射

3. 编写数据层代码

// POJO类如下:

public class User {

private String userId;

private String username;

private String password;

// Getters & Setters ..

}

// 数据层代码如下:

public interface UserMapper {

@Select("select * from t_user where 1=1")

List list();

@Select("select * from t_user where username like #{username}")

List findByUsername(String username);

@Select("select * from t_user where user_id like #{userId}")

User getOne(String userId);

@Delete("delete from t_user where user_id like #{userId}")

int delete(String userId);

}

4. 添加数据库记录

在Navicat 连接本地数据库,随便打开查询窗口,复制下面这段脚本,点击执行即可。

DROP DATABASE IF EXISTS `socks`;

CREATE DATABASE `socks`;

USE `SOCKS`;

DROP TABLE IF EXISTS `t_user`;

CREATE TABLE `t_user` (

`USER_ID` varchar(50) ,

`USERNAME` varchar(50) ,

`PASSWORD` varchar(50)

) ;

INSERT INTO `t_user` VALUES ('1', 'admin', 'admin');

INSERT INTO `t_user` VALUES ('2', 'yizhiwazi', '123456');

5. 启动项目

@SpringBootApplication

@MapperScan("com.hehe.mapper") //扫描Mapper接口

public class MybatisApplication {

public static void main(String[] args) {

SpringApplication.run(MybatisApplication.class, args);

}

}

6. 单元测试

import static org.assertj.core.api.Assertions.assertThat;

@RunWith(SpringRunner.class)

@SpringBootTest

public class MybatisApplicationTest {

@SuppressWarnings("all")

@Autowired

UserMapper userMapper;

@Test

public void test_db() {

//开始进行测试

assertThat(userMapper.list().size()).isGreaterThan(1);

assertThat(userMapper.getOne("1")).isNotEqualTo(null);

assertThat(userMapper.getOne("xxx")).isEqualTo(null);

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:浅谈synchronized方法对非synchronized方法的影响
下一篇:Java 从互联网上爬邮箱代码示例
相关文章

 发表评论

暂时没有评论,来抢沙发吧~