免费在线a视频-免费在线观看a视频-免费在线观看大片影视大全-免费在线观看的视频-色播丁香-色播基地

太強了!這款輕量級的數據庫中間件完美解決了SpringBoot中分庫分表問題?

:2020年06月27日 Java面試那些事兒
分享到:

一、 Sharding-jdbc簡介Sharding-jdbc是開源的數據庫操作中間件;定位為輕量級Java框架,在Java的JDBC層提供的額外服務。它使用客戶端直連數據庫,以jar包形式提供服務,無需額外部署和依賴,可理解為增...

一、 Sharding-jdbc簡介

Sharding-jdbc是開源的數據庫操作中間件;定位為輕量級Java框架,在Java的JDBC層提供的額外服務。它使用客戶端直連數據庫,以jar包形式提供服務,無需額外部署和依賴,可理解為增強版的JDBC驅動,完全兼容JDBC和各種ORM框架。

官方文檔地址:https://shardingsphere.apache.org/document/current/cn/overview

本文demo實現了分庫分表功能。如有錯誤,歡迎各位在評論中指出。不勝感激!

二、項目結構

首先創建一個一般的Spring boot項目,項目采用三層架構,結構圖如下:

POM.xml文件如下:

<?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>

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>2.1.6.RELEASE</version>

<relativePath/> <!-- lookup parent from repository -->

</parent>

<groupId>com.macky</groupId>

<artifactId>spring-boot-shardingjdbc</artifactId>

<version>0.0.1-SNAPSHOT</version>

<name>spring-boot-shardingjdbc</name>

<description>Demo project for spring-boot-shardingjdbc</description>

<properties>

<java.version>1.8</java.version>

</properties>

<dependencies>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

<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-Plus-->

<dependency>

<groupId>com.baomidou</groupId>

<artifactId>mybatis-plus-boot-starter</artifactId>

<version>3.1.1</version>

</dependency>

<!--shardingsphere start-->

<!-- for spring boot -->

<dependency>

<groupId>io.shardingsphere</groupId>

<artifactId>sharding-jdbc-spring-boot-starter</artifactId>

<version>3.1.0</version>

</dependency>

<!-- for spring namespace -->

<dependency>

<groupId>io.shardingsphere</groupId>

<artifactId>sharding-jdbc-spring-namespace</artifactId>

<version>3.1.0</version>

</dependency>

<!--shardingsphere end-->

<!--lombok-->

<dependency>

<groupId>org.projectlombok</groupId>

<artifactId>lombok</artifactId>

</dependency>

</dependencies>

<build>

<plugins>

<plugin>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-maven-plugin</artifactId>

</plugin>

</plugins>

</build>

</project>

實體類以書本為例

package com.macky.springbootshardingjdbc.entity;

import com.baomidou.mybatisplus.annotation.TableName;

import com.baomidou.mybatisplus.extension.activerecord.Model;

import groovy.transform.EqualsAndHashCode;

import lombok.Data;

import lombok.experimental.Accessors;

/**

* @author Macky

* @Title class Book

* @Description: 書籍是實體類

* @date 2019/7/13 15:23

*/

@Data

@EqualsAndHashCode(callSuper = true)

@Accessors(chain = true)

@TableName("book")

public class Book extends Model<Book> {

private int id;

private String name;

private int count;}

開放保存和查詢兩個接口,代碼如下:

package com.macky.springbootshardingjdbc.controller;

import com.macky.springbootshardingjdbc.entity.Book;

import com.macky.springbootshardingjdbc.service.BookService;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.*;

import java.util.List;

/**

* @author Macky

* @Title class BookController

* @Description: TODO

* @date 2019/7/12 20:53

*/

@RestController

public class BookController {

@Autowired

BookService bookService;

@RequestMapping(value = "/book", method = RequestMethod.GET)

public List<Book> getItems(){

return bookService.getBookList();

}

@RequestMapping(value = "/book",method = RequestMethod.POST)

public Boolean saveItem(Book book){

return bookService.save(book);

}

}

BookServiceImpl.java

package com.macky.springbootshardingjdbc.service.impl;

import com.baomidou.mybatisplus.core.toolkit.Wrappers;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;

import com.macky.springbootshardingjdbc.entity.Book;

import com.macky.springbootshardingjdbc.mapper.BookMapper;

import com.macky.springbootshardingjdbc.service.BookService;

import org.springframework.stereotype.Service;

import java.util.List;

/**

* @author Macky

* @Title class BookServiceImpl

* @Description: TODO

* @date 2019/7/12 20:47

*/

@Service

public class BookServiceImpl extends ServiceImpl<BookMapper, Book> implements BookService {

@Override

public List<Book> getBookList() {

return baseMapper.selectList(Wrappers.<Book>lambdaQuery());

}

@Override

public boolean save(Book book) {

return super.save(book);

}

}

BookMapper.java

package com.macky.springbootshardingjdbc.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;

import com.macky.springbootshardingjdbc.entity.Book;

/**

* @author Macky

* @Title class BookMapper

* @Description: TODO

* @date 2019/7/12 20:46

*/

public interface BookMapper extends BaseMapper<Book> {

}

創建數據庫表,DDL語句如下

創建數據庫表數據

CREATE DATABASE IF NOT EXISTS `db0`;

USE `db0`;

DROP TABLE IF EXISTS `book_0`;

CREATE TABLE `book_0` (

`id` INT ( 11 ) NOT NULL,

`name` VARCHAR ( 255 ) DEFAULT NULL,

`count` INT ( 11 ) DEFAULT NULL,

PRIMARY KEY ( `id` )

) ENGINE = INNODB DEFAULT CHARSET = utf8mb4;

DROP TABLE IF EXISTS `book_1`;

CREATE TABLE `book_1` (

`id` INT ( 11 ) NOT NULL,

`name` VARCHAR ( 255 ) DEFAULT NULL,

`count` INT ( 11 ) DEFAULT NULL,

PRIMARY KEY ( `id` )

) ENGINE = INNODB DEFAULT CHARSET = utf8mb4;

CREATE DATABASE IF NOT EXISTS `db1`;

USE `db1`;

DROP TABLE IF EXISTS `book_0`;

CREATE TABLE `book_0` (

`id` INT ( 11 ) NOT NULL,

`name` VARCHAR ( 255 ) DEFAULT NULL,

`count` INT ( 11 ) DEFAULT NULL,

PRIMARY KEY ( `id` )

) ENGINE = INNODB DEFAULT CHARSET = utf8mb4;

DROP TABLE IF EXISTS `book_1`;

CREATE TABLE `book_1` (

`id` INT ( 11 ) NOT NULL,

`name` VARCHAR ( 255 ) DEFAULT NULL,

`count` INT ( 11 ) DEFAULT NULL,

PRIMARY KEY ( `id` )

) ENGINE = INNODB DEFAULT CHARSET = utf8mb4;

CREATE DATABASE IF NOT EXISTS `db2`;

USE `db2`;

DROP TABLE IF EXISTS `book_0`;

CREATE TABLE `book_0` (

`id` INT ( 11 ) NOT NULL,

`name` VARCHAR ( 255 ) DEFAULT NULL,

`count` INT ( 11 ) DEFAULT NULL,

PRIMARY KEY ( `id` )

) ENGINE = INNODB DEFAULT CHARSET = utf8mb4;

DROP TABLE IF EXISTS `book_1`;

CREATE TABLE `book_1` (

`id` INT ( 11 ) NOT NULL,

`name` VARCHAR ( 255 ) DEFAULT NULL,

`count` INT ( 11 ) DEFAULT NULL,

PRIMARY KEY ( `id` )

) ENGINE = INNODB DEFAULT CHARSET = utf8mb4;

配置分庫分表策略application.properties:

# 數據源 db0,db1,db2

sharding.jdbc.datasource.names=db0,db1,db2

# 第一個數據庫

sharding.jdbc.datasource.db0.type=com.zaxxer.hikari.HikariDataSource

sharding.jdbc.datasource.db0.driver-class-name=com.mysql.cj.jdbc.Driver

sharding.jdbc.datasource.db0.jdbc-url=jdbc:mysql://localhost:3306/db0?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC

sharding.jdbc.datasource.db0.username=root

sharding.jdbc.datasource.db0.password=Aa123456

# 第二個數據庫

sharding.jdbc.datasource.db1.type=com.zaxxer.hikari.HikariDataSource

sharding.jdbc.datasource.db1.driver-class-name=com.mysql.cj.jdbc.Driver

sharding.jdbc.datasource.db1.jdbc-url=jdbc:mysql://localhost:3306/db1?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC

sharding.jdbc.datasource.db1.username=root

sharding.jdbc.datasource.db1.password=Aa123456

# 第三個數據庫

sharding.jdbc.datasource.db2.type=com.zaxxer.hikari.HikariDataSource

sharding.jdbc.datasource.db2.driver-class-name=com.mysql.cj.jdbc.Driver

sharding.jdbc.datasource.db2.jdbc-url=jdbc:mysql://localhost:3306/db2?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC

sharding.jdbc.datasource.db2.username=root

sharding.jdbc.datasource.db2.password=Aa123456

# 水平拆分的數據庫(表) 配置分庫 + 分表策略 行表達式分片策略

# 分庫策略

sharding.jdbc.config.sharding.default-database-strategy.inline.sharding-column=id

sharding.jdbc.config.sharding.default-database-strategy.inline.algorithm-expression=db$->{id % 3}

# 分表策略 其中book為邏輯表 分表主要取決于id行

sharding.jdbc.config.sharding.tables.book.actual-data-nodes=db$->{0..2}.book_$->{0..2}

sharding.jdbc.config.sharding.tables.book.table-strategy.inline.sharding-column=count

# 分片算法表達式

sharding.jdbc.config.sharding.tables.book.table-strategy.inline.algorithm-expression=book_$->{count % 3}

# 主鍵 UUID 18位數 如果是分布式還要進行一個設置 防止主鍵重復

#sharding.jdbc.config.sharding.tables.user.key-generator-column-name=id

# 打印執行的數據庫以及語句

sharding.jdbc.config.props..sql.show=true

spring.main.allow-bean-definition-overriding=true

#讀寫分離

sharding.jdbc.datasource.dsmaster =

接口測試使用postman

示例:GET請求------>http://localhost:8080/book POST請求:------->http://localhost:8080/book?id=1&name=java編程思想&count=8

三、總結

分庫分表實現按照官方文檔做一個demo是第一步,如需深入還需要研究源碼,

研究架構,研究思想;此文僅作為入門demo搭建指南,如需深入理解,還請移步

至官方文檔。

參考資料

  • 官方文檔:https://shardingsphere.apache.org/document/current/cn/manual/sharding-jdbc/usage/sharding/

[我要糾錯]
文:王振袢&發表于江蘇
關鍵詞: Sharding-jdbc 簡介 Sharding-jdbc 開源 數據庫

來源:本文內容搜集或轉自各大網絡平臺,并已注明來源、出處,如果轉載侵犯您的版權或非授權發布,請聯系小編,我們會及時審核處理。
聲明:江蘇教育黃頁對文中觀點保持中立,對所包含內容的準確性、可靠性或者完整性不提供任何明示或暗示的保證,不對文章觀點負責,僅作分享之用,文章版權及插圖屬于原作者。

點個贊
0
踩一腳
0

您在閱讀:太強了!這款輕量級的數據庫中間件完美解決了SpringBoot中分庫分表問題?

Copyright©2013-2025 ?JSedu114 All Rights Reserved. 江蘇教育信息綜合發布查詢平臺保留所有權利

蘇公網安備32010402000125 蘇ICP備14051488號-3技術支持:南京博盛藍睿網絡科技有限公司

南京思必達教育科技有限公司版權所有   百度統計

主站蜘蛛池模板: 色图综合| 黄色aⅴ| 日日日天天射天天干视频 | 国产精品亚洲精品日韩已方 | 欧美成人精品欧美一级乱黄 | 一级福利视频 | 国产人免费人成免费视频 | 男女靠逼网站 | 午夜精品国产爱在线观看不卡 | 免费观看黄a一级视频 | 日本人亚洲人成人 | 亚洲日本黄色片 | a视频在线免费观看 | 日本日b | 澳门一级特黄真人毛片 | 五月激情综合网 | 521a成v视频网站在线入口 | 在线免费观看色视频 | 精品国产亚洲人成在线 | 中文字幕日韩理论在线 | 欧美人视频在线观看视频 | 男女羞羞视频免费观看 | 亚洲另类视频 | 国产97免费视频 | 在线永久免费播放视频 | 日韩激情小视频 | 成人看片黄a毛片 | 国产成人精品免费2021 | 国产高清啪啪 | 91亚洲国产成人久久精品网站 | 在线精品日韩一区二区三区 | 亚洲视频中文字幕在线观看 | 国产综合免费视频 | 美女被cao免费看在线看网站 | 亚洲综合久久一本伊伊区 | 成熟女人50岁一级毛片不卡 | 免费色视频 | 天天舔天天 | 一区二区国产在线播放 | 亚洲色图图 | 亚洲女人国产香蕉久久精品 |
最熱文章
最新文章
  • 阿里云上云鉅惠,云產品享最低成本,有需要聯系,
  • 卡爾蔡司鏡片優惠店,鏡片價格低
  • 蘋果原裝手機殼