• SpringBoot集成MySQL


    MySQL环境搭建

    采用docker-compose搭建,配置如下:

    
    version: '3'
    services:
      mysql:
        image: registry.cn-hangzhou.aliyuncs.com/zhengqing/mysql:5.7  # 原镜像`mysql:5.7`
        container_name: mysql_3306                                    # 容器名为'mysql_3306'
        restart: unless-stopped                                       # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器
        volumes:                                                      # 数据卷挂载路径设置,将本机目录映射到容器目录
          - "./mysql/my.cnf:/etc/mysql/my.cnf"
          - "./mysql/init-file.sql:/etc/mysql/init-file.sql"
          - "./mysql/data:/var/lib/mysql"
    #      - "./mysql/conf.d:/etc/mysql/conf.d"
          - "./mysql/log/mysql/error.log:/var/log/mysql/error.log"
          - "./mysql/docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d" # 可执行初始化sql脚本的目录 -- tips:`/var/lib/mysql`目录下无数据的时候才会执行(即第一次启动的时候才会执行)
        environment:                        # 设置环境变量,相当于docker run命令中的-e
          TZ: Asia/Shanghai
          LANG: en_US.UTF-8
          MYSQL_ROOT_PASSWORD: root         # 设置root用户密码
          MYSQL_DATABASE: demo              # 初始化的数据库名称
        ports:                              # 映射端口
          - "3306:3306"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    启动mysql容器

    docker-compose -f docker-compose.yml -p mysql5.7 up -d

    创建user表并插入数据

    
    CREATE TABLE `user` (
     `id` int(11) NOT NULL AUTO_INCREMENT,
     `name` varchar(100) DEFAULT NULL,
     `age` int(11) DEFAULT NULL,
     PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCRE
    INSERT INTO demo.`user`(id, name, age)VALUES(1, 'jack', 18);
    INSERT INTO demo.`user`(id, name, age)VALUES(2, 'alyssa', 19);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    一、依赖

    
    <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">
        <parent>
            <artifactId>springboot-demoartifactId>
            <groupId>com.etgroupId>
            <version>1.0-SNAPSHOTversion>
        parent>
        <modelVersion>4.0.0modelVersion>
    
        <artifactId>mysqlartifactId>
    
        <properties>
            <maven.compiler.source>8maven.compiler.source>
            <maven.compiler.target>8maven.compiler.target>
        properties>
        <dependencies>
    
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-webartifactId>
            dependency>
    
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-autoconfigureartifactId>
            dependency>
            
            <dependency>
                <groupId>mysqlgroupId>
                <artifactId>mysql-connector-javaartifactId>
                <version>8.0.29version>
            dependency>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-jdbcartifactId>
            dependency>
            <dependency>
                <groupId>com.baomidougroupId>
                <artifactId>mybatis-plus-boot-starterartifactId>
                <version>3.5.1version>
            dependency>
            <dependency>
                <groupId>org.projectlombokgroupId>
                <artifactId>lombokartifactId>
            dependency>
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-starter-testartifactId>
                <scope>testscope>
            dependency>
    
        dependencies>
    project>
    
    • 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
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55

    二、application.yaml和启动类

    
    server:
      port: 8088
    
    spring:
      datasource:
        driver-class-name: com.mysql.cj.jdbc.Driver
        type: com.zaxxer.hikari.HikariDataSource
        url: jdbc:mysql://127.0.0.1:3306/demo?useUnicode=true&characterEncoding=utf-8&useSSL=false
        username: root
        password: root
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    三、entity实体类

    @Data
    @NoArgsConstructor
    @AllArgsConstructor
    @TableName("user")
    public class UserPO {
        @TableId(value = "id",type = IdType.AUTO)
        private int id;
        @TableField("name")
        private String name;
        @TableField("age")
        private int age;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    四、mapper接口

    @Repository
    public interface UserMapper extends BaseMapper<UserPO> {
    }
    
    • 1
    • 2
    • 3

    测试:

    @RunWith(SpringRunner.class)
    @SpringBootTest(classes = DemoApplication.class)
    public class MysqlTests {
        @Autowired
        private UserMapper userMapper;
    
    
        @Test
        public void testmysql(){
            for (UserPO userPO : userMapper.selectList(null)) {
                System.out.println(userPO.toString());
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  • 相关阅读:
    windows配置FTP服务
    统一网关Gateway、路由断言工厂、路由过滤器及跨域问题处理
    开设自己的网站系类02配置服务器
    进程相关知识总结
    Git——关于Git的一些补充(1)
    小白版:如何运行vue项目(后端+前端)
    【面试】什么是Java堆内存溢出?
    ssm分页实战
    爱上开源之DockerUI-安装部署Nenux私有仓库
    Leetcode(135)——分发糖果
  • 原文地址:https://blog.csdn.net/usa_washington/article/details/136495765