1. 程式人生 > >第04章—整合Mybatis

第04章—整合Mybatis

sel 前端 mysql put var logs void apache dem

spring boot 系列學習記錄:http://www.cnblogs.com/jinxiaohang/p/8111057.html

碼雲源碼地址:https://gitee.com/jinxiaohang/springboot

SSM框架中接觸過Spring整合Mybatis。

一、引入依賴

如果是新建項目的,可以在這頁添加依賴;

技術分享圖片

如果是原有項目,還可以在pom.xml 引入ORM框架(Mybaits-Starter)和數據庫驅動(MySQL-Conn)的依賴。

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.xiaohang</groupId> <artifactId>springboot-mybatis</artifactId> <
version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>springboot-mybatis</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId
>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <!--添加Web依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--添加Test依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!--添加MySQL驅動依賴 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <!--添加Mybatis依賴 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.1</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>

二、添加數據源

application.properties也可以配置,但語法上有些不同而已。

在application.yml 添加數據源,以及開啟Mybaits的駝峰映射功能。

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/test?useSSL=false
    username: root
    password: root
    driver-class-name: com.mysql.jdbc.Driver

mybatis:
  configuration:
   map-underscore-to-camel-case: true #開啟駝峰映射

三、編寫各層代碼

// entity類如下:
public class User {
    private String userId;
    private String username;
    private String password;
    // Getters & Setters ..
}
// dao層代碼如下:
@Component
public interface UserMapper {

    @Select("select * from user")
    List<User> list();

    @Select("select * from user where userId = #{userId}")
    User getOne(String userId);

    @Insert("insert into user(userId,username,password) values(#{userId},#{username},#{password})")
    boolean save(User user);

    @Update("update user set username=#{username},password=#{password} where userId=#{userId}")
    boolean update(User user);

    @Delete("delete from user where userId = #{userId}")
    boolean delete(String userId);
}

//service層
//
serviceImpl層
//controller層
這些都和之前接觸的類似,所以不在羅列,具體可以參照上面上傳的代碼


四、添加數據庫記錄

mysql> DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `userId` varchar(50) ,
  `username` varchar(50) ,
  `password` varchar(50) 
) ;

INSERT INTO `user` VALUES (1, admin, admin);
INSERT INTO `user` VALUES (2, yizhiwazi, 123456);

五、啟動項目

@SpringBootApplication
@MapperScan("com.xiaohang.springbootmybatis.dao")//新添加的註解
public class SpringbootMybatisApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringbootMybatisApplication.class, args);
    }
}

六、測試

運用火狐瀏覽器或者postman進行測試。

本篇重點關鍵在於依賴的添加文件配置、和一些註解的使用,其他都和接觸過的ssm、ssh差不多。

因為測試是件很麻煩的事,而且對於這樣的接口進行測試,還要與前端的需求統一,所以下一章將學習swagger。

第04章—整合Mybatis