美文网首页java
1.简单搭建 SpringBoot+SqLite+MyBatis

1.简单搭建 SpringBoot+SqLite+MyBatis

作者: IT_李晓 | 来源:发表于2018-08-07 17:07 被阅读0次

工具:

IntelliJ IDEA 2018.2 x64

Navicat Premium 12

涉及:

SpringBoot

SqLite

MyBatis

Swagger2

Lombok


1、使用idea创建SpringBoot项目,添加web和MyBatis支持。


New Project

2、修改pom.xml文件。添加swagger、lombok、SQLite驱动支持。

<?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.lio</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>demo</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.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>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.2</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <!-- swagger 驱动 -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.7.0</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.7.0</version>
        </dependency>

        <!-- druid 驱动 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.9</version>
        </dependency>

        <!-- lombok 驱动 -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.2</version>
        </dependency>

        <!-- SQLite 驱动 -->
        <dependency>
            <groupId>org.xerial</groupId>
            <artifactId>sqlite-jdbc</artifactId>
            <version>3.21.0.1</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>

3、利用IDEA快速添加SqLite,点击IDEA右侧的 Database >> + >> Data Source >> Sqlite

Database

4、未添加过Sqlite驱动的需要添加驱动,点击 Sqlite(Xerial) >> + >> provided Drive >> Xerial SQLiteJDBC >> latest version

Add Sqlite Driver

5、创建dome.db数据文件。
Name:数据源名称,随意填写。
File:指定数据文件,点击 + 号可创建文件,如果存在db文件则点击 ... 选择文件路径。
Test Connection:点击测试连接是否正常。

Create dome.db

6、用Navicat打开dome.db,创建user_info表。打开Navicat 将创建好的dome.db直接拖入Navicat即可,建表不做说明。


dome.db

7、为IDEA添加Lombok插件。
File >> Settings >> Plugins >> 输入lombok >> 点击安装

add Lombok Plugin

8、创建SwaggerConfig.java配置文件。

package com.lio.demo.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@Configuration
@EnableSwagger2
public class SwaggerConfig {
    @Bean
    public Docket createDocket() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.lio.demo.controller"))
                .paths(PathSelectors.any())
                .build();
    }

    public ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("MyBatis + SqLite 测试程序")
                .termsOfServiceUrl("NO terms of service")
                .version("1.0")
                .build();
    }
}

9、修改启动类,添加@EnableSwagger2注解,启用Swagger2。

package com.lio.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@SpringBootApplication
@EnableSwagger2
public class DemoApplication {

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

10、创建UserInfo的实体类,这里使用到Lombok的@Data注解。

package com.lio.demo.model;

import lombok.Data;

@Data
public class UserInfoModel {
    private Integer id;
    private String name;
    private Integer age;
    private String sex;
}

11、创建UserInfoDao,添加@Mapper注解,声明Mapper。

package com.lio.demo.dao;

import com.lio.demo.model.UserInfoModel;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.SelectProvider;
import org.springframework.stereotype.Component;

import java.util.List;

@Mapper
@Component
public interface UserInfoDao {

    @SelectProvider(type = UserInfoMapper.class,method = "findUserInfoList")
    List<UserInfoModel> findUserInfoList(String id);

}

12、创建UserInfoMapper。

package com.lio.demo.dao;

import com.alibaba.druid.util.StringUtils;
import org.apache.ibatis.jdbc.SQL;


public class UserInfoMapper {

    public String findUserInfoList(String id){
        SQL sql = new SQL();
        sql.SELECT("id,name,age,sex");
        sql.FROM("user_info");
        if(!StringUtils.isEmpty(id)){
            sql.WHERE("id=#{id}");
        }
        return sql.toString();
    }
}

13、创建UserInfoService。

package com.lio.demo.service;

import com.lio.demo.dao.UserInfoDao;
import com.lio.demo.model.UserInfoModel;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class UserInfoService {

    @Autowired
    private UserInfoDao userInfoDao;

    public List<UserInfoModel> findUserInfoList(String id){
        return userInfoDao.findUserInfoList(id);
    }
}

14、创建UserInfoController。

package com.lio.demo.controller;

import com.lio.demo.model.UserInfoModel;
import com.lio.demo.service.UserInfoService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
@RequestMapping(value = "/user")
@Api(value = "用户类" ,tags = "用户操作接口")
public class UserInfoController {

    @Autowired
    private UserInfoService userInfoService;

    @GetMapping(value = "/findUserInfoList")
    @ApiOperation(value="获取用户列表", notes="获取用户列表")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "id", value = "用户ID", required = false, paramType = "query")
    })
    public List<UserInfoModel> findUserInfoList(String id){
        return userInfoService.findUserInfoList(id);
    }
}

15、至此代码已经写完了,启动程序进入Swagger测试。
Swagger地址:http://localhost:8080/swagger-ui.html

Swagger

代码已经上传至码云
源码下载
参考
mybatis官方文档
swagger2常用注解说明
Lombok介绍

相关文章

  • 1.简单搭建 SpringBoot+SqLite+MyBatis

    工具: IntelliJ IDEA 2018.2 x64 Navicat Premium 12 涉及: Sprin...

  • Spring MVC之实例初体验

    1.环境搭建 Spring MVC的环境搭建比较简单,如果是创建的是Maven项目,只需要简单的加入Spring ...

  • 直播服务搭建教程

    1. 直播服务器搭建 搭建SRS直播服务器非常简单, a). 下载源码git clone https://git...

  • 用JavaScript带你学go-第一章 开发环境

    1.开发环境的搭建 1.1JavaScript的环境搭建(以后简称js) js的环境很简单,一个前端html的搭配...

  • gitlub私服搭建

    title: gitlub私服的搭建 最近应公司需求,搭建gitlab私服,在这里做一个简单的记录。 1.安装和配...

  • 【dubbo】1.简单spring-dubbo工程搭建

    工程目录结构 : pom依赖 dubbo-api 只提供简单的服务接口UserService接口: ==如果是ge...

  • SpringBoot+MySQL简单搭建

    一. 简单项目搭建 1. 右键目录空白new project选择Maven Project 2. 创建一个简单的项...

  • 1.搭建环境

    这次要学习的是慕课网的Python升级3.6 强力Django+杀手级Xadmin打造在线教育平台。写着3.6但是...

  • 1.页面搭建

    利用代码来搭建界面。 plist文件内容 可见视图所需要的属性 解析plist文件,创建模型 AppModel.h...

  • 1.搭建框架

    搭建项目框架 1.创建一个根视图 (window)2 根视图上添加根控制器 tabbarController3...

网友评论

    本文标题:1.简单搭建 SpringBoot+SqLite+MyBatis

    本文链接:https://www.haomeiwen.com/subject/dvsavftx.html