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

做的网站怎么让百度收索时搜网站建设培训机构

做的网站怎么让百度收索时搜,网站建设培训机构,网站建设万网,怎么建设音乐试听网站1 分表分库 LogicTable 数据分片的逻辑表#xff0c;对于水平拆分的数据库(表)#xff0c;同一类表的总称。 订单信息表拆分为2张表,分别是t_order_0、t_order_1#xff0c;他们的逻辑表名为t_order。 ActualTable 在分片的数据库中真实存在的物理表。即上个示例中的t_…1 分表分库 LogicTable 数据分片的逻辑表对于水平拆分的数据库(表)同一类表的总称。 订单信息表拆分为2张表,分别是t_order_0、t_order_1他们的逻辑表名为t_order。 ActualTable 在分片的数据库中真实存在的物理表。即上个示例中的t_order_0、t_order_1。 DataNode 数据分片的最小单元。由数据源名称和数据表组成例test_msg0.t_order_0。配置时默认各个分片数据库的表结构均相同直接配置逻辑表和真实表对应关系即可。 ShardingColumn 分片字段。用于将数据库(表)水平拆分的关键字段。SQL中如果无分片字段将执行全路由性能较差。Sharding-JDBC支持多分片字段。 ShardingAlgorithm 分片算法。Sharding-JDBC通过分片算法将数据分片支持通过等号、BETWEEN和IN分片。分片算法目前需要业务方开发者自行实现可实现的灵活度非常高。未来Sharding-JDBC也将会实现常用分片算法如rangehash和tag等。 2 自定义分片模式 2.1 数据库表结构 创建ds_0数据库新建表如下 CREATE TABLE t_order_0 (order_id bigint(20) NOT NULL,user_id bigint(20) NOT NULL,PRIMARY KEY (order_id) ) ENGINEInnoDB DEFAULT CHARSETutf8 COLLATEutf8_bin;CREATE TABLE t_order_1 (order_id bigint(20) NOT NULL,user_id bigint(20) NOT NULL,PRIMARY KEY (order_id) ) ENGINEInnoDB DEFAULT CHARSETutf8 COLLATEutf8_bin; 3 新建maven项目 parentgroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-parent/artifactIdversion2.0.3.RELEASE/versionrelativePath / !-- lookup parent from repository --/parentpropertiesproject.build.sourceEncodingUTF-8/project.build.sourceEncodingproject.reporting.outputEncodingUTF-8/project.reporting.outputEncodingjava.version1.8/java.version/propertiesdependencies!-- jpa --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-jpa/artifactId/dependencydependencygroupIdorg.mybatis.spring.boot/groupIdartifactIdmybatis-spring-boot-starter/artifactIdversion1.3.2/version/dependencydependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdscoperuntime/scope/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependencydependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactIdoptionaltrue/optional/dependency!-- 引入shardingjdbc依赖信息 --dependencygroupIdio.shardingjdbc/groupIdartifactIdsharding-jdbc-core/artifactIdversion2.0.3/version/dependencydependencygroupIdcom.dangdang/groupIdartifactIdsharding-jdbc-self-id-generator/artifactIdversion1.4.2/version/dependencydependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactId/dependencydependencygroupIdcom.alibaba/groupIdartifactIddruid/artifactIdversion1.0.12/version/dependency/dependenciesbuildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build4 application配置 ###数据库访问连接 spring:jdbc:db0:password: 123456className: com.mysql.jdbc.Driverurl: jdbc:mysql://192.168.222.157:3306/%s?characterEncodingutf-8username: rootjpa:database: mysqlshow-sql: truehibernate:## 自己建表ddl-auto: noneapplication:name: sharding-jdbc-first 5 配置分表算法 5.1 配置数据库连接 package com.example.demo.config;import com.alibaba.druid.pool.DruidDataSource; import com.dangdang.ddframe.rdb.sharding.api.ShardingDataSourceFactory; import com.dangdang.ddframe.rdb.sharding.api.rule.DataSourceRule; import com.dangdang.ddframe.rdb.sharding.api.rule.ShardingRule; import com.dangdang.ddframe.rdb.sharding.api.rule.TableRule; import com.dangdang.ddframe.rdb.sharding.api.strategy.table.TableShardingStrategy; import com.dangdang.ddframe.rdb.sharding.id.generator.IdGenerator; import com.dangdang.ddframe.rdb.sharding.id.generator.self.CommonSelfIdGenerator; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;import javax.sql.DataSource; import java.util.Arrays; import java.util.HashMap; import java.util.Map;// 数据源相关配置信息 Configuration public class DataSourceConfig {Value(${spring.jdbc.db0.className})private String className;Value(${spring.jdbc.db0.url})private String url;Value(${spring.jdbc.db0.username})private String username;Value(${spring.jdbc.db0.password})private String password;Beanpublic IdGenerator getIdGenerator() {return new CommonSelfIdGenerator();}Beanpublic DataSource getDataSource() {return buildDataSource();}private DataSource buildDataSource() {// 1.设置分库映射MapString, DataSource dataSourceMap new HashMap(2);dataSourceMap.put(ds_0, createDataSource(ds_0));// dataSourceMap.put(ds_1, createDataSource(ds_1));// 设置默认db为ds_0也就是为那些没有配置分库分表策略的指定的默认库// 如果只有一个库也就是不需要分库的话map里只放一个映射就行了只有一个库时不需要指定默认库// 但2个及以上时必须指定默认库否则那些没有配置策略的表将无法操作数据DataSourceRule rule new DataSourceRule(dataSourceMap, ds_0);// 2.设置分表映射将t_order_0和t_order_1两个实际的表映射到t_order逻辑表TableRule orderTableRule TableRule.builder(t_order).actualTables(Arrays.asList(t_order_0, t_order_1)).dataSourceRule(rule).build();// 3.具体的分库分表策略ShardingRule shardingRule ShardingRule.builder().dataSourceRule(rule).tableRules(Arrays.asList(orderTableRule))// 根据userid分片字段.tableShardingStrategy(new TableShardingStrategy(user_id, new TableShardingAlgorithm())).build();// 创建数据源DataSource dataSource ShardingDataSourceFactory.createDataSource(shardingRule);return dataSource;}private DataSource createDataSource(String dataSourceName) {// 使用druid连接数据库DruidDataSource druidDataSource new DruidDataSource();druidDataSource.setDriverClassName(className);druidDataSource.setUrl(String.format(url, dataSourceName));druidDataSource.setUsername(username);druidDataSource.setPassword(password);return druidDataSource;} }5.2 配置分表策略 分表算法类需要实现SingleKeyTableShardingAlgorithmT接口 package com.example.demo.config;import com.dangdang.ddframe.rdb.sharding.api.ShardingValue; import com.dangdang.ddframe.rdb.sharding.api.strategy.table.SingleKeyTableShardingAlgorithm;import java.util.Collection;// 表分片算法 public class TableShardingAlgorithm implements SingleKeyTableShardingAlgorithmLong {// sql 中关键字 匹配符为 的时候表的路由函数public String doEqualSharding(CollectionString availableTargetNames, ShardingValueLong shardingValue) {for (String tableName : availableTargetNames) {if (tableName.endsWith(shardingValue.getValue() % 2 )) {return tableName;}}throw new IllegalArgumentException();}Overridepublic CollectionString doInSharding(CollectionString availableTargetNames, ShardingValueLong shardingValue) {return null;}Overridepublic CollectionString doBetweenSharding(CollectionString availableTargetNames,ShardingValueLong shardingValue) {return null;}}6 新建实体类 package com.example.demo.entity;import lombok.Data;import javax.persistence.Entity; import javax.persistence.Id; import javax.persistence.Table;Data Entity Table(name t_order) public class OrderEntity {Idprivate Long orderId;private Long userId;} 7 OrderRepository package com.example.demo.repository;import com.example.demo.entity.OrderEntity; import org.springframework.data.jpa.repository.Query; import org.springframework.data.repository.CrudRepository;import java.util.List;public interface OrderRepository extends CrudRepositoryOrderEntity, Long {Query(value SELECT order_id ,user_id FROM t_order where order_id in (?1);, nativeQuery true)public ListOrderEntity findExpiredOrderState(ListString bpIds); } 8 OrderController package com.example.demo.controller;import com.example.demo.entity.OrderEntity; import com.example.demo.repository.OrderRepository; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import java.util.ArrayList; import java.util.List;RestController public class OrderController {Autowiredprivate OrderRepository orderRepository;// 查询所有的订单信息RequestMapping(/getOrderAll)public ListOrderEntity getOrderAll() {return (ListOrderEntity) orderRepository.findAll();}// 使用in条件查询RequestMapping(/inOrder)public ListOrderEntity inOrder() {ListString ids new ArrayList();ids.add(2);ids.add(3);ids.add(4);ids.add(5);return orderRepository.findExpiredOrderState(ids);}// 增加RequestMapping(/inserOrder)public String inserOrder(OrderEntity orderEntity) {for (int i 0; i 10; i) {OrderEntity order new OrderEntity();order.setOrderId((long) i);order.setUserId((long) i);orderRepository.save(order);}return success;}}9 新建启动类 package com.example.demo;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.data.jpa.repository.config.EnableJpaRepositories;SpringBootApplication EnableJpaRepositories(basePackages com.example.demo.repository) public class AppSharding {public static void main(String[] args) {SpringApplication.run(AppSharding.class, args);} }10 启动项目 访问http://localhost:8080/inserOrder 查看数据库 分表测试成功
http://www.sadfv.cn/news/311718/

相关文章:

  • 英文商城网站昆明做百度网站电话
  • 微信微网站模板下载佛山网站建设专家评价
  • 建站赚钱灰色招工信息发布平台
  • 无锡大型网站建设公司西安关键词快速排名
  • 做个网站需要什么设备福州设计网站
  • 满山红网站建设公司wordpress链接 颜色
  • 建设政务网站报告wordpress会员收费权限
  • 上海网站营销是什么做网站经常用的字体有哪些
  • 建设网站需要公司吗wordpress后台管理界面地址
  • 网站建设服务好公司排名注册科技公司需要什么条件
  • 土巴兔网站开发关于建设网站的报告
  • 建设派网站手机网站主机
  • 专业的建设机械网站制作织梦网站图片移动
  • 盐城网站开发包括哪些北京旅游设计网站建设
  • 网站建设公司douyanet视觉设计专业就业前景
  • 携程旅行网站内容的建设湛江网站建设方案优化
  • 海丰网站制作做任务的奖金网站
  • 九江公司网站建设做网站客户没有付定金
  • 建设高端网站公司北京网站建设公司房山华网
  • 最专业的网站开发公司哪家最专业wordpress做h5
  • 中兴建设云南有限公司网站网站建设项目的预算
  • 网站开发有前途吗口碑营销案例有哪些
  • 品牌创意型网站建设芮城网站开发
  • 企业网站模板下载网址用自己的照片做头像的网站
  • 东莞企业网站建设多少钱可信网站认证有用吗
  • 外行学习个人网站建设wordpress 开关 边栏 选择 模板
  • 想做个小网站怎么做如何构建网站
  • 文明网站建设总结h5网站需要哪些技术
  • 网站改版了深圳龙华鸿宇大厦网站建设
  • 网站推广排名教程网络营销优化