目录
利用Java实现
利用数据库实现
举个栗子
两种方法的实现
利用Java实现
(高可用)JAVA一:可以直接使用我粘贴在这里的工具类
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
/**
* @desc 判断一个数值,是否在一个区间内
* @author liren
* @date 2018年4月30日 11:23:59
*/
public class IntervalUtil {
/**
* 判断data_value是否在interval区间范围内
* @param data_value 数值类型的
* @param interval 正常的数学区间,包括无穷大等,如:(1,3)、>5%、(-∞,6]、(125%,135%)U(70%,80%)
* @return true:表示data_value在区间interval范围内,false:表示data_value不在区间interval范围内
*/
public static boolean isInTheInterval(String data_value,String interval) {
//将区间和data_value转化为可计算的表达式
String formula = getFormulaByAllInterval(data_value,interval,"||");
ScriptEngine jse = new ScriptEngineManager().getEngineByName("JavaScript");
try {
//计算表达式
return (Boolean) jse.eval(formula);
} catch (Exception t) {
return false;
}
}
/**
* 将所有阀值区间转化为公式:如
* [75,80) =》 date_value < 80 && date_value >= 75
* (125%,135%)U(70%,80%) =》 (date_value < 1.35 && date_value > 1.25) || (date_value < 0.8 && date_value > 0.7)