成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現分庫分表功能

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

Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現分庫分表功能

一、 Sharding-jdbc簡介“

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

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

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

二、項目結構

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

Spring Boot 集成 Sharding-JDBC + Mybatis-Plus 實現分庫分表功能

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> {}

創建數據庫表,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:

> 推薦一個艿艿寫的 3000+ Star 的 SpringCloud Alibaba 電商開源項目的倉庫:<https://github.com/YunaiV/onemall> # 數據源 db0,db1,db2sharding.jdbc.datasource.names=db0,db1,db2# 第一個數據庫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 # 第二個數據庫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 # 第三個數據庫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 # 水平拆分的數據庫(表) 配置分庫 + 分表策略 行表達式分片策略# 分庫策略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位數 如果是分布式還要進行一個設置 防止主鍵重復#sharding.jdbc.config.sharding.tables.user.key-generator-column-name=id # 打印執行的數據庫以及語句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鼓勵鼓勵博主,謝謝!

三、總結

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

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

標簽: Spring
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
成人午夜大片免费观看| 亚洲高清在线精品| 中文字幕一区在线观看| 成人美女视频在线观看18| 欧美少妇性性性| 婷婷久久综合九色综合绿巨人| 亚洲私人影院| 中文字幕二三区不卡| 91美女在线观看| 亚洲精品在线电影| 成人高清视频在线| 日韩精品中午字幕| 国产成人久久精品77777最新版本| 欧美日韩亚洲不卡| 免费人成在线不卡| 久久午夜精品| 亚洲欧美另类久久久精品2019| 欧美日韩在线精品| 国产精品色在线| 欧美日韩三区| 国产精品美女久久久久久2018 | 激情小说欧美图片| 欧美亚洲另类激情小说| 青青草成人在线观看| 久久久久久久久一区二区| 一二三区精品福利视频| 国产女主播一区二区| 亚洲一区视频在线观看视频| 妖精视频成人观看www| 久久精品国产99国产精品| 亚洲精品一区二区三区四区高清 | 国产亚洲欧美色| 91精品国产丝袜白色高跟鞋| 国产一区三区三区| 一区二区三区|亚洲午夜| 亚洲在线中文字幕| 色哟哟一区二区在线观看 | 一区二区三区国产| 国产欧美日韩在线播放| 1024成人网| 国产精品伊人日日| 日韩av在线发布| 欧美亚洲一区二区在线| 韩国v欧美v日本v亚洲v| 欧美日韩大陆一区二区| 国产精品综合二区| 2023国产一二三区日本精品2022| 91欧美激情一区二区三区成人| 国产精品污www在线观看| av成人免费观看| 日韩专区欧美专区| 在线观看91av| 91同城在线观看| 亚洲图片欧美激情| 国产一区二区三区免费不卡| 五月激情六月综合| 7777精品久久久大香线蕉| gogogo免费视频观看亚洲一| 中文字幕在线不卡国产视频| 免费在线亚洲欧美| 激情小说亚洲一区| 久久久不卡影院| 亚洲激情另类| 日韩av一区二区在线影视| 678五月天丁香亚洲综合网| av男人天堂一区| 中文字幕在线观看不卡视频| 嫩草成人www欧美| 国产毛片一区二区| 久久久99免费| 99精品福利视频| 美日韩黄色大片| 久久女同互慰一区二区三区| 伊人久久久大香线蕉综合直播| 亚洲一区免费在线观看| 欧美中文字幕一区二区三区亚洲| 国产91色综合久久免费分享| 国产精品乱人伦| 亚洲欧美精品| 国产黄色成人av| **性色生活片久久毛片| 色屁屁一区二区| www.视频一区| 一卡二卡三卡日韩欧美| 欧美剧情片在线观看| 91日韩精品一区| 亚洲r级在线视频| 日韩免费成人网| 一级成人国产| 国产综合一区二区| 国产精品久久午夜夜伦鲁鲁| 久久人人九九| 不卡在线视频中文字幕| 亚洲最快最全在线视频| 在线综合+亚洲+欧美中文字幕| 国内外成人免费视频| 久久99精品网久久| 国产精品免费观看视频| 欧美性videosxxxxx| 午夜国产精品视频免费体验区| 亚洲成av人片一区二区三区| 精品久久久久久无| 国产精品三上| 高清不卡一区二区| 亚洲国产精品久久久久秋霞影院 | 色综合久久综合网欧美综合网| 午夜在线一区| 国产亚洲美州欧州综合国| 日韩精品免费专区| 影音先锋久久资源网| 欧美日韩极品在线观看一区| 一区二区三区在线观看网站| 成人爽a毛片一区二区免费| 日本久久一区二区| 亚洲卡通欧美制服中文| 欧美在线国产| 欧美一区二区久久| 婷婷久久综合九色国产成人| 亚洲欧美亚洲| 欧美成人vr18sexvr| 久久精品国产网站| 国产亚洲欧美一区二区三区| 久久久久9999亚洲精品| 国产成人啪午夜精品网站男同| 国产欧美日韩亚洲| 国产精品色眯眯| 成人小视频免费在线观看| 欧美日韩性生活| 日本美女一区二区三区| 国产伦精品一区二区三区| 国产精品家庭影院| 不卡av电影在线播放| 欧美日韩一级二级三级| 亚洲成人动漫在线免费观看| 亚洲国产影院| 国产精品灌醉下药二区| 欧美二区不卡| 国产精品天天看| 亚洲第一在线| 亚洲妇女屁股眼交7| 一本久道久久综合婷婷鲸鱼| 99精品99久久久久久宅男| 狠狠入ady亚洲精品经典电影| 欧美男人的天堂一二区| 亚洲综合999| av成人天堂| 亚洲精品视频免费观看| 激情五月婷婷综合网| 99久久精品99国产精品| 色噜噜狠狠色综合欧洲selulu| 成年人国产精品| 蜜桃av一区二区三区电影| 中文字幕一区二区5566日韩| 丝袜美腿成人在线| 狠狠干成人综合网| 日韩美女在线视频| 亚洲一二三区视频在线观看| 影音先锋久久久| 色综合天天综合狠狠| 国产成人高清视频| 韩国v欧美v日本v亚洲v| 免费的国产精品| 日韩激情一区二区| 亚洲综合免费观看高清在线观看| 国产精品第13页| 欧美激情一区二区三区在线| 精品国产在天天线2019| 日韩一区二区免费在线观看| 欧美日本一区二区在线观看| 欧美综合亚洲图片综合区| 亚洲一区三区在线观看| 亚洲片区在线| 亚洲第一黄网| 日韩视频久久| 99re热精品| 一二三区精品| 国产精品亚洲一区| 国产乱码精品| 免费毛片一区二区三区久久久| 亚洲深夜激情| 国产亚洲精品v| 欧美亚洲在线| 久热精品在线| 在线视频你懂得一区| 在线精品观看国产| 美玉足脚交一区二区三区图片| 性欧美精品高清| 久久九九精品| 91精彩视频在线| 欧美激情 亚洲a∨综合| 中文字幕一区三区| 欧美丝袜第三区| 91视频在线观看| 五月天丁香久久| 国产午夜精品一区二区三区四区| 久久久久久婷| 欧美日韩国产色综合一二三四| 日本va欧美va精品| 中文一区在线播放| 欧美日韩高清在线|