Google Guava学习 - Guava Range类 - Sharding范围分片使用

本文介绍了Google Guava库中的Range类,主要用于数据范围的处理。通过示例代码展示了如何使用Range进行操作,并提到了在Sharding分片场景下的应用。同时,提供了两个参考资料供进一步学习。

1.功能:数据范围处理

2.代码:

package com.example.google.guava.demo.clazz;


import com.google.common.collect.ContiguousSet;

import com.google.common.collect.DiscreteDomain;

import com.google.common.collect.Range;

import com.google.common.primitives.Ints;


/**

* <p>

* <code>RangeTest</code>

* </p>

* Description:

*

* @author Mcchu

* @date 2017/10/19 9:06

*/

public class RangeTest {


public static void main(String[] args) {

testRange();

}


private static void testRange(){

// 1.使用Range.closed()创建范围: [a,b] = { x | a <= x <= b}

Range<Integer> range1 = Range.closed(0, 9);

System.out.println("新建数据范围range1:"+range1);

printRange(range1);


// 1.1包含关系

Boolean containVal = range1.contains(1);

Boolean containAllVal1 = range1.containsAll(Ints.asList(1,3,5));

Boolean containAllVal2 = range1.containsAll(Ints.asList(1,3,5,12));

System.out.println("是否包含1:"+containVal);

System.out.println("是否包含1,3,5:"+containAllVal1);

System.o
我基于shardingJDBC 5.1.2版本开发了自定义分片算法,请帮忙补充一个完整测试用例,要求可直接允许 import com.google.common.collect.Lists; import com.google.common.collect.Range; import lombok.NoArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.time.DateUtils; import org.apache.shardingsphere.sharding.api.sharding.standard.PreciseShardingValue; import org.apache.shardingsphere.sharding.api.sharding.standard.RangeShardingValue; import org.apache.shardingsphere.sharding.api.sharding.standard.StandardShardingAlgorithm; import org.apache.shardingsphere.sharding.spi.ShardingAlgorithm; import org.springframework.stereotype.Component; import java.util.Calendar; import java.util.Collection; import java.util.Date; import java.util.Locale; import java.util.Properties; @Slf4j @NoArgsConstructor @Component public class SalesDateShardingAlgorithm implements StandardShardingAlgorithm<String>, ShardingAlgorithm { private Properties properties; private static final String SEPERATOR = "-"; private static final String NOTABLE = "_NOT_EXIST"; private static final String TABLE_SDF = "%s_%s%s"; @Override public String doSharding(Collection<String> collection, PreciseShardingValue<String> preciseShardingValue) { String loginTableName = preciseShardingValue.getLogicTableName(); String date = preciseShardingValue.getValue(); if (log.isDebugEnabled()) { log.info(", sharding {} ", date); } String[] items = date.split(SEPERATOR, -1); if (collection.contains(StringUtils.lowerCase(String.format(TABLE_SDF, loginTableName, items[0], items[1])))) { return String.format(TABLE_SDF, loginTableName, items[0], items[1]); } return loginTableName + NOTABLE; } @Override public Collection<String> doSharding(Collection<String> availableTables, RangeShardingValue<String> rangeShardingValue) { Collection<String> tableList = Lists.newLinkedList(); String logicTableName = rangeShardingValue.getLogicTableName().toLowerCase(Locale.ROOT); Range<String> dates = rangeShardingValue.getValueRange(); try { if (log.isDebugEnabled()) { log.info("tableName : {}, begin : {} end : {}", logicTableName, dates.lowerEndpoint(), dates.upperEndpoint()); } // 动态计算日期范围 Date start = DateUtils.parseDate(dates.lowerEndpoint(), "yyyy-MM-dd HH:mm:ss"); Date end = DateUtils.parseDate(dates.upperEndpoint(), "yyyy-MM-dd HH:mm:ss"); Calendar cal = Calendar.getInstance(); cal.setTime(start); while (cal.getTime().compareTo(end) == 0 || cal.getTime().before(end)) { String month = cal.get(Calendar.YEAR) + String.format("%02d", cal.get(Calendar.MONTH) + 1); String table = String.format(TABLE_SDF, logicTableName, month.substring(0, 4), month.substring(4)); if (availableTables.contains(table)) { tableList.add(table); } else { tableList.add(logicTableName + NOTABLE); } cal.add(Calendar.MONTH, 1); } } catch (Exception e) { log.error("doSharding error", e); throw new BffException(e.getMessage()); } if (log.isDebugEnabled()) { log.info("res : {}", tableList); } return tableList; } @Override public Properties getProps() { return properties; } @Override public void init(Properties properties) { this.properties = properties; } public String getType() { return "SalesDateShardingAlgorithm"; } }
最新发布
09-02
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值