<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

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

          共 8077字,需瀏覽 17分鐘

           ·

          2020-07-15 09:11

          來源:https://blog.csdn.net/Macky_He/article/details/95754402 作者:Macky_He

          一、 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)了分庫分表功能。如有錯誤,歡迎各位在評論中指出。不勝感激!

          粉絲福利,點擊領(lǐng)取?教妹子手擼了50個項目實戰(zhàn)后,我住院了……

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

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

          3efdf630fcfad2734928ec376e5fa326.webpPOM.xml文件如下:

                   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    4.0.0            org.springframework.boot        spring-boot-starter-parent        2.1.6.RELEASE                 com.macky    spring-boot-shardingjdbc    0.0.1-SNAPSHOT    spring-boot-shardingjdbc    Demo project for spring-boot-shardingjdbc
          1.8
          org.springframework.boot spring-boot-starter-web
          org.springframework.boot spring-boot-starter-test test mysql mysql-connector-java runtime com.baomidou mybatis-plus-boot-starter 3.1.1 io.shardingsphere sharding-jdbc-spring-boot-starter 3.1.0 io.shardingsphere sharding-jdbc-spring-namespace 3.1.0 org.projectlombok lombok
          org.springframework.boot spring-boot-maven-plugin

          實體類以書本為例

          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 { 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 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 implements BookService {
          @Override public List getBookList() { return baseMapper.selectList(Wrappers.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 {}

          創(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:

          # 數(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è)置 防止主鍵重復#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搭建指南,如需深入理解,還請移步至官方文檔。

          參考資料

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

          最后免費給大家分享50個Java項目實戰(zhàn)資料,涵蓋入門、進階各個階段學習內(nèi)容,可以說非常全面了。大部分視頻還附帶源碼,學起來還不費勁!


          附上截圖。(下面有下載方式)。

          4c95b8a9f1b9f2e12e235bd9865cd0c9.webp

          7ce56ce1529586aa75183641f6163440.webp

          84c873ad71038c2e3c6c4ecccce2cbe7.webp

          af4d5bf603f2e4448144f9cf1ce02d1b.webp

          998cd21a06c924ef7aef5d356ff027b9.webp


          項目領(lǐng)取方式:

          掃描下方公眾號回復:50

          可獲取下載鏈接

          ???

          ?長按上方二維碼?2 秒回復「50」即可獲取資料

          點贊是最大的支持?041eae83011944bd9f4580031715878f.webp

          瀏覽 38
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  国产成人在线免费视频 | 一本大道久久无码精品一区二区三区 | 91午夜福利视频 | 国产女人操B | 91aiai |