日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現(xiàn)分庫分表功能

瀏覽:166日期:2023-08-19 11:00:29

Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現(xiàn)分庫分表功能

一、 Sharding-jdbc簡介“

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

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

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

二、項目結(jié)構(gòu)

首先創(chuàng)建一個一般的Spring boot項目,項目采用三層架構(gòu),結(jié)構(gòu)圖如下:

Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現(xiàn)分庫分表功能

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 */@RestControllerpublic 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 */@Servicepublic 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> {}

創(chuàng)建數(shù)據(jù)庫表,DDL語句如下

創(chuàng)建數(shù)據(jù)庫表數(shù)據(jù)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:

> 推薦一個艿艿寫的 3000+ Star 的 SpringCloud Alibaba 電商開源項目的倉庫:<https://github.com/YunaiV/onemall> # 數(shù)據(jù)源 db0,db1,db2sharding.jdbc.datasource.names=db0,db1,db2# 第一個數(shù)據(jù)庫sharding.jdbc.datasource.db0.type=com.zaxxer.hikari.HikariDataSourcesharding.jdbc.datasource.db0.driver-class-name=com.mysql.cj.jdbc.Driversharding.jdbc.datasource.db0.jdbc-url=jdbc:mysql://localhost:3306/db0?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTCsharding.jdbc.datasource.db0.username=rootsharding.jdbc.datasource.db0.password=Aa123456 # 第二個數(shù)據(jù)庫sharding.jdbc.datasource.db1.type=com.zaxxer.hikari.HikariDataSourcesharding.jdbc.datasource.db1.driver-class-name=com.mysql.cj.jdbc.Driversharding.jdbc.datasource.db1.jdbc-url=jdbc:mysql://localhost:3306/db1?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTCsharding.jdbc.datasource.db1.username=rootsharding.jdbc.datasource.db1.password=Aa123456 # 第三個數(shù)據(jù)庫sharding.jdbc.datasource.db2.type=com.zaxxer.hikari.HikariDataSourcesharding.jdbc.datasource.db2.driver-class-name=com.mysql.cj.jdbc.Driversharding.jdbc.datasource.db2.jdbc-url=jdbc:mysql://localhost:3306/db2?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTCsharding.jdbc.datasource.db2.username=rootsharding.jdbc.datasource.db2.password=Aa123456 # 水平拆分的數(shù)據(jù)庫(表) 配置分庫 + 分表策略 行表達式分片策略# 分庫策略sharding.jdbc.config.sharding.default-database-strategy.inline.sharding-column=idsharding.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位數(shù) 如果是分布式還要進行一個設(shè)置 防止主鍵重復(fù)#sharding.jdbc.config.sharding.tables.user.key-generator-column-name=id # 打印執(zhí)行的數(shù)據(jù)庫以及語句sharding.jdbc.config.props..sql.show=truespring.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的github地址:

https://github.com/Macky-He/spring-boot--shardingsphere-examples 如各位覺得有幫助的話,還請給個star鼓勵鼓勵博主,謝謝!

三、總結(jié)

分庫分表實現(xiàn)按照官方文檔做一個demo是第一步,如需深入還需要研究源碼,研究架構(gòu),研究思想;此文僅作為入門demo搭建指南,如需深入理解,還請移步至官方文檔。

到此這篇關(guān)于Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現(xiàn)分庫分表功能的文章就介紹到這了,更多相關(guān)Spring Boot實現(xiàn)分庫分表內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美色综合网| 日韩精品一二三区| 国产精品毛片久久久| 综合一区av| 国产婷婷精品| 噜噜噜久久亚洲精品国产品小说| 欧美日韩在线观看视频小说| 蜜桃tv一区二区三区| 日韩午夜免费| 亚洲精品进入| 国产日韩欧美一区二区三区 | 日韩激情精品| 国产精品欧美大片| 久久天堂影院| 色老板在线视频一区二区| 久久精品在线| 妖精视频成人观看www| 亚洲尤物av| 欧美久久一区二区三区| 久久久久久久久成人| 国产福利电影在线播放| 国产精品99视频| 激情久久婷婷| 亚洲午夜久久| 麻豆久久久久久| 亚洲精品在线影院| 午夜国产精品视频| 日本欧美一区| 日韩国产在线| 中文字幕日韩高清在线| 国产精品麻豆成人av电影艾秋| 精品日韩一区| 国产一区白浆| 国产精品亚洲片在线播放| 成人午夜网址| 99国产精品99久久久久久粉嫩| 日韩中文字幕一区二区高清99| 精品一区二区三区中文字幕| 欧美日韩国产综合网| 国产日韩欧美高清免费| 四虎影视精品| 深夜福利亚洲| 免费观看亚洲| 日本亚洲三级在线| 色婷婷综合网| 亚洲精品无播放器在线播放| 麻豆成人综合网| 亚洲一区二区三区四区五区午夜 | 精品一区二区三区四区五区| 久久久水蜜桃av免费网站| 久久亚洲风情| 成人在线视频区| 亚洲精品少妇| 欧美日韩视频免费观看| 欧美日韩91| 99国产精品| 国内揄拍国内精品久久| 免费看欧美美女黄的网站| 精品久久久中文字幕| 国产精品外国| 超碰在线99| 青草av.久久免费一区| 日韩精品一区二区三区免费观影 | 国产成人精品三级高清久久91| 午夜精品一区二区三区国产| 国产精成人品2018| 日韩在线a电影| 日韩一区自拍| 国产日产一区| 三级亚洲高清视频| 日韩欧美一区二区三区免费看| 日韩不卡一区二区三区| 亚洲精品网址| 天堂中文av在线资源库| 在线一区二区三区视频| 久久精品二区三区| 精品一区二区三区免费看| 四虎精品永久免费| 五月天激情综合网| 亚洲一级少妇| 国内精品麻豆美女在线播放视频| 天堂av一区| 午夜在线精品偷拍| 欧美日韩一区二区三区视频播放| 欧美成人aaa| 美女亚洲一区| 久久青青视频| 麻豆精品新av中文字幕| 欧美三级第一页| 尹人成人综合网| 日韩在线免费| 视频在线不卡免费观看| 久久国产精品色av免费看| 亚洲影视一区二区三区| 一区久久精品| 五月激情久久| 毛片在线网站| 黄色欧美在线| 里番精品3d一二三区| 欧美在线看片| 日本va欧美va瓶| 亚洲精品一区二区在线播放∴| 99成人在线| 午夜亚洲精品| 99免费精品| 国产一区二区三区日韩精品| 国产伦乱精品| 欧美日韩视频免费看| 一区二区国产精品| 黄色在线一区| 在线日韩视频| 亚洲激情久久| 亚洲男女av一区二区| 国产99精品一区| 国产尤物精品| 国产精品99一区二区| 久久要要av| 激情婷婷亚洲| 亚洲激情黄色| 日韩午夜av在线| 久久亚洲影院| 亚洲不卡视频| 国产日韩欧美三级| 久久av综合| 在线一区欧美| 亚洲资源在线| 日本成人精品| 国产精品巨作av| 久久在线91| 国产精品专区免费| 久久久久蜜桃| 亚洲精品一二三区区别| 免播放器亚洲| 日韩不卡手机在线v区| 欧美日韩黄网站| 欧美成人aaa| 亚洲性色av| 午夜精品影院| 亚洲精品在线二区| 国产精品入口久久| 免费观看亚洲| 国产亚洲亚洲| 日韩超碰人人爽人人做人人添| 国产精品亚洲欧美日韩一区在线| 麻豆成人av在线| 国产亚洲一区二区手机在线观看 | 在线观看免费一区二区| 国产婷婷精品| 久久精品凹凸全集| 国产不卡精品在线| 欧美亚洲国产激情| 中文字幕免费一区二区| 国产日韩亚洲欧美精品| av资源新版天堂在线| 欧美aa国产视频| 亚洲ab电影| 成人在线免费观看91| 欧美大黑bbbbbbbbb在线| 老牛影视一区二区三区 | 久久国产精品亚洲77777| 欧美日一区二区在线观看| 日韩av免费大片| av不卡免费看| 国产精品免费99久久久| 伊人久久高清| 综合精品一区| 麻豆网站免费在线观看| 欧美福利一区| 国产欧美亚洲精品a| 亚洲伦乱视频| 日韩成人午夜精品| 日韩欧美午夜| 婷婷亚洲精品| 激情黄产视频在线免费观看| 久热精品在线| 久久久久久一区二区| 蘑菇福利视频一区播放| 久久久精品国产**网站| 一区在线视频观看| 久久不卡日韩美女| 99国产精品久久久久久久成人热 | 一区二区小说| 日韩成人午夜精品| 麻豆精品蜜桃| 午夜性色一区二区三区免费视频| 日韩av在线中文字幕| 亚洲欧美在线综合| 久久夜夜操妹子| 国产欧美日韩一区二区三区四区| 999精品在线| 国产精品videossex久久发布| 亚洲欧美日韩高清在线| 久久亚洲精品中文字幕| 久久性天堂网| 私拍精品福利视频在线一区| 欧美精品中文| 午夜在线观看免费一区| 欧美成人a交片免费看| 久久国产免费看| 一本色道精品久久一区二区三区|