【Sharding Sphere、Spring Boot】Spring Boot整合Sharding Sphere Proxy(5.0.0)

一、Sharding Sphere基本介绍

官网链接推荐:跳转官网 | 5.0.0中文文档 | 快速入门

二、Spring Boot整合Sharding Sphere Proxy

1、安装Sharding Sphere Proxy环境

参考地址:【Docker、Sharding Sphere】Docker安装Sharding Sphere Proxy-5.0.0

2、相关pom.xml依赖

		<!-- mysql驱动-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <!-- mybatis-plus -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.3.1</version>
        </dependency>

3、创建Mybatis映射相关文件

在这里插入图片描述
注意: @TableName注解中得表名需和代理数据库中得一致
在这里插入图片描述

4、application.yml配置

server:
  port: 7208
  servlet:
    context-path: /sharding_sphere/proxy

spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:7009/sharding_proxy_db?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true
    username: root
    password: root

5、测试接口

package com.cyun.demo.sharding.sphere.proxy.controller;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
import com.cyun.core.result.ResultVO;
import com.cyun.demo.sharding.sphere.proxy.entity.SysLog;
import com.cyun.demo.sharding.sphere.proxy.service.impl.SysLogServiceImpl;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;

/**
 * @author He PanFu
 * @date 2022-04-20 11:39:11
 */
@Slf4j
@RestController
@RequestMapping("/test")
@RequiredArgsConstructor
public class TestController {

    private final SysLogServiceImpl sysLogService;

    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

    @GetMapping(value = "/by_date")
    public ResultVO byDate() throws ParseException {
        QueryWrapper queryWrapper = new QueryWrapper();
        queryWrapper.between("create_time", sdf.parse("2022-04-01 00:59:59"), sdf.parse("2022-04-28 00:59:59"));
        final List list = sysLogService.list(queryWrapper);
        return ResultVO.ok(list.size());
    }

    @GetMapping(value = "/add/{logType}")
    public ResultVO add(@PathVariable("logType") Integer logType) {
        SysLog sysLog = SysLog.builder()
                .id(IdWorker.getIdStr())
                .applicationName("sharding-sphere-server")
                .logType(logType)
                .operateType(2)
                .logContent("测试")
                .ip("127.0.0.1")
                .method("测试")
                .requestUrl("测试")
                .requestParam("测试")
                .requestType("get")
                .costTime(5L)
                .createBy("123")
                .createTime(new Date())
                .updateBy("123")
                .updateTime(new Date())
                .build();

        sysLogService.save(sysLog);
        return ResultVO.ok();
    }
}

6、测试

测试新增

请求url
在这里插入图片描述

实际数据库表数据
在这里插入图片描述
代理数据库表数据
在这里插入图片描述

测试查询

请求url
在这里插入图片描述
结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值