当前位置: 首页 > news >正文

免备案手机网站室内设计网站免费素材

免备案手机网站,室内设计网站免费素材,有专门做宝宝用品的网站吗,不懂外贸做外贸网站好做吗1. 数据准备 1. 在mysql-server01服务器上, 创建数据库 course_db 2. 创建表 t_course_1 、 t_course_2 3. 约定规则:如果添加的课程 id 为偶数添加到 t_course_1 中,奇数添加到t_course_2 中。水平分片的id需要在业务层实现,不能依赖数据库的…

1. 数据准备

1.	在mysql-server01服务器上, 创建数据库 course_db
2.	创建表 t_course_1 、 t_course_2
3.	约定规则:如果添加的课程 id 为偶数添加到 t_course_1 中,奇数添加到t_course_2 中。
水平分片的id需要在业务层实现,不能依赖数据库的主键自增
CREATE TABLE t_course_1 (
`cid` BIGINT(20) NOT NULL,
`user_id` BIGINT(20) DEFAULT NULL,
`cname` VARCHAR(50) DEFAULT NULL,
`brief` VARCHAR(50) DEFAULT NULL,
`price` DOUBLE DEFAULT NULL,
`status` INT(11) DEFAULT NULL,
PRIMARY KEY (`cid`)
) ENGINE=INNODB DEFAULT CHARSET=utf8
CREATE TABLE t_course_2 (
`cid` BIGINT(20) NOT NULL,
`user_id` BIGINT(20) DEFAULT NULL,
`cname` VARCHAR(50) DEFAULT NULL,
`brief` VARCHAR(50) DEFAULT NULL,
`price` DOUBLE DEFAULT NULL,
`status` INT(11) DEFAULT NULL,
PRIMARY KEY (`cid`)
) ENGINE=INNODB DEFAULT CHARSET=utf8

2. 配置文件

# 应用名称
spring.application.name=sharding-jdbc
# 打印SQl
spring.shardingsphere.props.sql-show=true# 定义多个数据源
spring.shardingsphere.datasource.names = db1#数据源1
spring.shardingsphere.datasource.db1.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.db1.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.db1.jdbc-url=jdbc:mysql://localhost:3306/course_db?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.shardingsphere.datasource.db1.username=root
spring.shardingsphere.datasource.db1.password=root#1.配置数据节点 指定t_course逻辑表表的真实分布情况
# t_course: 逻辑表
spring.shardingsphere.rules.sharding.tables.t_course.actual-data-nodes=db1.t_course_$->{1..2}#2.配置分片策略(包括分片键和分片算法)
#2.1 分片键名称 cid
spring.shardingsphere.rules.sharding.tables.t_course.table-strategy.standard.sharding-column=cid#2.2 分片算法
#----分片算法名称
spring.shardingsphere.rules.sharding.tables.t_course.table-strategy.standard.sharding-algorithm-name=table-inline
#----分片算法类型  --> 行表达式分片算法
spring.shardingsphere.rules.sharding.sharding-algorithms.table-inline.type=INLINE
#---分片算法的属性配置
spring.shardingsphere.rules.sharding.sharding-algorithms.table-inline.props.algorithm-expression=t_course_$->{cid % 2 + 1}

注意
分片算法名称table-inline是自定义的

行表达式的使用: https://shardingsphere.apache.org/document/5.1.1/cn/features/sharding/concept/inline-expression/)

3 测试

import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.ToString;@TableName("t_course")
@Data
@ToString
public class Course {private Long cid;private Long userId;private String cname;private String brief;private double price;private int status;}
@Mapper
public interface CourseMapper extends BaseMapper<Course> {
}
import com.simon.shardingjdbc.entity.Course;
import com.simon.shardingjdbc.mapper.CourseMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
public class ShardingjdbcApplicationTests {@Autowiredprivate CourseMapper courseMapper;@Testpublic void testInsertCourse(){for (int i = 0; i < 3; i++) {Course course = new Course();course.setCid(10010L + i);course.setUserId(1L+i);course.setCname("Java面试题详解");course.setBrief("经典的10000道面试题");course.setPrice(100.00);course.setStatus(1);courseMapper.insert(course);}}}

在这里插入图片描述
在这里插入图片描述

4. 分布式序列算法

雪花算法:
https://shardingsphere.apache.org/document/5.1.1/cn/features/sharding/concept/key-generator/
水平分片需要关注全局序列,因为不能简单的使用基于数据库的主键自增。

解决方案

一种是基于MyBatisPlus的id策略
一种是ShardingSphereJDBC的全局序列配置

基于MyBatisPlus的id策略:将Course类的id设置成如下形式

@TableName("t_course")
@Data
@ToString
public class Course {@TableId(value = "cid",type = IdType.ASSIGN_ID)private Long cid;private Long userId;private String cname;private String brief;private double price;private int status;}
import com.simon.shardingjdbc.entity.Course;
import com.simon.shardingjdbc.mapper.CourseMapper;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
public class ShardingjdbcApplicationTests {@Autowiredprivate CourseMapper courseMapper;@Testpublic void testInsertCourse(){for (int i = 0; i < 8; i++) {Course course = new Course();course.setUserId(1L+i);course.setCname("mybatis分布式id" + i);course.setBrief("mybatis分布式id");course.setPrice(130.00);course.setStatus(1);courseMapper.insert(course);}}}

在这里插入图片描述
在这里插入图片描述
基于ShardingSphere-JDBC的全局序列配置

#2.3 分布式序列配置
#---- 分布式序列的列名
spring.shardingsphere.rules.sharding.tables.t_course.key-generate-strategy.column=cid
#--- 分布式序列-算法名称
spring.shardingsphere.rules.sharding.tables.t_course.key-generate-strategy.key-generator-name=alg-snowflake
#--- 分布式序列-算法类型
spring.shardingsphere.rules.sharding.key-generators.alg-snowflake.type=SNOWFLAKE

完整的配置文件

# 应用名称
spring.application.name=sharding-jdbc
# 打印SQl
spring.shardingsphere.props.sql-show=true# 定义多个数据源
spring.shardingsphere.datasource.names = db1#数据源1
spring.shardingsphere.datasource.db1.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.db1.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.db1.jdbc-url=jdbc:mysql://localhost:3306/course_db?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.shardingsphere.datasource.db1.username=root
spring.shardingsphere.datasource.db1.password=root#1.配置数据节点 指定t_course逻辑表表的真实分布情况
# t_course: 逻辑表
spring.shardingsphere.rules.sharding.tables.t_course.actual-data-nodes=db1.t_course_$->{1..2}#2.配置分片策略(包括分片键和分片算法)
#2.1 分片键名称 cid
spring.shardingsphere.rules.sharding.tables.t_course.table-strategy.standard.sharding-column=cid#2.2 分片算法
#----分片算法名称
spring.shardingsphere.rules.sharding.tables.t_course.table-strategy.standard.sharding-algorithm-name=table-inline
#----分片算法类型  --> 行表达式分片算法
spring.shardingsphere.rules.sharding.sharding-algorithms.table-inline.type=INLINE
#---分片算法的属性配置
spring.shardingsphere.rules.sharding.sharding-algorithms.table-inline.props.algorithm-expression=t_course_$->{cid % 2 + 1}#2.3 分布式序列配置
#---- 分布式序列的列名
spring.shardingsphere.rules.sharding.tables.t_course.key-generate-strategy.column=cid
#--- 分布式序列-算法名称
spring.shardingsphere.rules.sharding.tables.t_course.key-generate-strategy.key-generator-name=alg-snowflake
#--- 分布式序列-算法类型
spring.shardingsphere.rules.sharding.key-generators.alg-snowflake.type=SNOWFLAKE

去除mybatis的分布式id注解

@TableName("t_course")
@Data
@ToString
public class Course {private Long cid;private Long userId;private String cname;private String brief;private double price;private int status;}

测试

@SpringBootTest
public class ShardingjdbcApplicationTests {@Autowiredprivate CourseMapper courseMapper;@Testpublic void testInsertCourse(){for (int i = 0; i < 8; i++) {Course course = new Course();course.setUserId(1L+i);course.setCname("sharding提供的雪花算法id" + i);course.setBrief("mybatis分布式id");course.setPrice(130.00);course.setStatus(1);courseMapper.insert(course);}}}

在这里插入图片描述
在这里插入图片描述

http://www.dtcms.com/a/583816.html

相关文章:

  • js 曲线 网站百度快照是啥
  • 郑州网站优化价格WordPress判断设备
  • Python SMTP详解
  • 网站seo源码网课培训机构排名前十
  • 湖南金辉建设集团有限公司网站聊城东昌府区建设路小学网站
  • 陕西网站建设多少钱手机设置管理网站首页
  • 景观网站设计网站广州高铁新建站在哪里
  • 大气产品展示网站源码公众号简介有趣的文案
  • 工作单元模式
  • 网站多语言建设tp5.1做的网站
  • 建设部网站监理公告app制作工具下载
  • 有想做企业网站建设鲜花网站建设方案
  • wordpress建立视频网站wordpress自动更新文章
  • 桂林学校网站制作自用电脑做网站
  • 在线网站seo诊断移动wifi多少钱一个月
  • 米拓做的网站如何改代码wordpress地址站点地址
  • 网站开发建设价格附件软件开发平台培训
  • 温州建设集团官方网站中国软件园排名前十
  • 网页广告代码成都抖音seo
  • 绿色固氮:颠覆传统农业与化工的低碳革命
  • 网站建设源代码怎么搭建wordpress 本地编辑
  • 如何设计网站中的上传功能茂名高端模板建站
  • 网站建设及经营应解决好的问题怎样在一个虚拟服务器里做两个网站
  • php旅游网站cmswordpress怎么卸载主题
  • 电商网站建设相关书籍推荐祥云平台技术支持双语网站
  • 程序员找工作的网站创建公司官网
  • 网站友链怎么添加做网站系统的过程
  • 建网站英文将wordpress部署
  • 湘潭做网站口碑好磐石网络电子产品去什么网站做站点
  • 深圳网站建设 设计卓越迈wordpress悬浮下拉