当前位置: 首页 > 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.zqtcl.cn/news/475263/

相关文章:

  • 杭州做代发的网站有哪些计算机基础网站建设和网络安全
  • 做汽配外贸是在哪个网站做山东百度推广
  • 网站类型大全cms监控软件下载官网
  • 网站设计制作 建网站免费asp地方门户网站系统
  • 凡科网做的网站保存后就上传了吗东莞网站推广建设
  • 网站推广案例闲鱼上做网站
  • 网站 做购物车分类信息网站建设系统
  • 网站做弹窗坂田建设网站
  • 北仑网站推广保险网站建设
  • 文山城乡建设部网站首页个人网站怎么注册
  • 西安企业建站wordpress外部调用后台
  • 江苏手机网站建设公司域名查询ip解析
  • 网站上的用户注册怎么做的苏州网站建设制作服务商
  • 网站开发模版宁波网
  • 以鹦鹉做头像的网站wordpress post是什么
  • 公司怎么建立自己网站做网站需要编码吗
  • 网站域名根目录在哪里wordpress做跟随导航导航
  • 昆明网站建站推广it外包工作怎么样
  • 上海长宁网站建设公司WordPress 采集文章 图片
  • 紫色 网站网络设计的最后一个步骤是
  • 广东省建设安全卡查询网站网站开发需要的语言
  • 网站的建设需要考虑什么问题投放广告的网站
  • 雅虎提交网站入口常州哪家做网站好
  • 哪些网站是503错误代码太原搭建网站的公司
  • 网站建设公司需要有什么东西凡科建站seo
  • 荷泽网站建设买链接做网站 利润高吗
  • 网站嵌套代码网络营销与策划实训
  • 网上做环评立项的网站是哪个网站开发是前端吗
  • 公司网站可以自己建立吗前端网站开发教程
  • 淘宝客导购网站营销推广软件有哪些