between.java
来自「mysql集群」· Java 代码 · 共 65 行
JAVA
65 行
/***************************************************************************** SQLJEP - Java SQL Expression Parser 0.2 November 1 2006 (c) Copyright 2006, Alexey Gaidukov SQLJEP Author: Alexey Gaidukov SQLJEP is based on JEP 2.24 (http://www.singularsys.com/jep/) (c) Copyright 2002, Nathan Funk See LICENSE.txt for license information. *****************************************************************************/package com.meidusa.amoeba.sqljep.function;import com.meidusa.amoeba.sqljep.function.Comparative;import com.meidusa.amoeba.sqljep.function.ComparativeComparator;import com.meidusa.amoeba.sqljep.function.PostfixCommand;import com.meidusa.amoeba.sqljep.ASTFunNode;import com.meidusa.amoeba.sqljep.JepRuntime;import com.meidusa.amoeba.sqljep.ParseException;public final class Between extends PostfixCommand { final public int getNumberOfParameters() { return 3; } public boolean isAutoBox() { return false; } public Comparable<?>[] evaluate(ASTFunNode node, JepRuntime runtime) throws ParseException { node.childrenAccept(runtime.ev, null); Comparable<?> limit2 = runtime.stack.pop(); Comparable<?> limit1 = runtime.stack.pop(); Comparable<?> source = runtime.stack.pop(); return new Comparable<?>[] { source, limit1, limit2 }; } public Comparable<?> getResult(Comparable<?>... comparables) throws ParseException { Comparable<?> limit2 = comparables[2]; Comparable<?> limit1 = comparables[1]; Comparable<?> source = comparables[0]; if (source == null || limit1 == null || limit2 == null) { return (Boolean.FALSE); } else { if (source instanceof Comparative) { Comparative other = (Comparative) source; boolean result = other.intersect( Comparative.GreaterThanOrEqual, limit1, ComparativeComparator.comparator); result = result && other.intersect(Comparative.LessThanOrEqual, limit2, ComparativeComparator.comparator); return (result); } else { return (ComparativeComparator.compareTo(source, limit1) >= 0 && ComparativeComparator .compareTo(source, limit2) <= 0); } } }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?