亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? comparelike.java

?? 非常棒的java數(shù)據(jù)庫
?? JAVA
字號:
/*
 * Copyright 2004-2008 H2 Group. Licensed under the H2 License, Version 1.0
 * (http://h2database.com/html/license.html).
 * Initial Developer: H2 Group
 */
package org.h2.expression;

import java.sql.SQLException;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;

import org.h2.constant.ErrorCode;
import org.h2.engine.Constants;
import org.h2.engine.Session;
import org.h2.index.IndexCondition;
import org.h2.message.Message;
import org.h2.table.ColumnResolver;
import org.h2.table.TableFilter;
import org.h2.util.StringUtils;
import org.h2.value.CompareMode;
import org.h2.value.Value;
import org.h2.value.ValueBoolean;
import org.h2.value.ValueNull;
import org.h2.value.ValueString;

/**
 * Pattern matching comparison expression: WHERE NAME LIKE ?
 */
public class CompareLike extends Condition {

    private final CompareMode compareMode;
    private final boolean regexp;
    private Expression left;
    private Expression right;
    private Expression escape;

    private boolean isInit;
    private char[] pattern;
    private String patternString;
    private Pattern patternRegexp;
    private int[] types;
    private int patternLength;
    private static final int MATCH = 0, ONE = 1, ANY = 2;
    private boolean ignoreCase;

    public CompareLike(CompareMode compareMode, Expression left, Expression right, Expression escape, boolean regexp) {
        this.compareMode = compareMode;
        this.regexp = regexp;
        this.left = left;
        this.right = right;
        this.escape = escape;
    }

    public String getSQL() {
        String sql;
        if (regexp) {
            sql = left.getSQL() + " REGEXP " + right.getSQL();
        } else {
            sql = left.getSQL() + " LIKE " + right.getSQL();
            if (escape != null) {
                sql += " ESCAPE " + escape.getSQL();
            }
        }
        return "(" + sql + ")";
    }

    public Expression optimize(Session session) throws SQLException {
        left = left.optimize(session);
        right = right.optimize(session);
        if (left.getType() == Value.STRING_IGNORECASE) {
            ignoreCase = true;
        }
        if (left.isValueSet()) {
            Value l = left.getValue(session);
            if (l == ValueNull.INSTANCE) {
                // NULL LIKE something > NULL
                return ValueExpression.NULL;
            }
        }
        if (escape != null) {
            escape = escape.optimize(session);
        }
        if (right.isValueSet() && (escape == null || escape.isValueSet())) {
            if (left.isValueSet()) {
                return ValueExpression.get(getValue(session));
            }
            Value r = right.getValue(session);
            if (r == ValueNull.INSTANCE) {
                // something LIKE NULL > NULL
                return ValueExpression.NULL;
            }
            Value e = escape == null ? null : escape.getValue(session);
            if (e == ValueNull.INSTANCE) {
                return ValueExpression.NULL;
            }
            String pattern = r.getString();
            initPattern(pattern, getEscapeChar(e));
            if ("%".equals(pattern)) {
                // optimization for X LIKE '%': convert to X IS NOT NULL
                return new Comparison(session, Comparison.IS_NOT_NULL, left, null).optimize(session);
            }
            if (isFullMatch()) {
                // optimization for X LIKE 'Hello': convert to X = 'Hello'
                Value value = ValueString.get(patternString);
                Expression expr = ValueExpression.get(value);
                return new Comparison(session, Comparison.EQUAL, left, expr).optimize(session);
            }
            isInit = true;
        }
        return this;
    }

    private char getEscapeChar(Value e) throws SQLException {
        if (e == null) {
            return Constants.DEFAULT_ESCAPE_CHAR;
        }
        String es = e.getString();
        char esc;
        if (es == null || es.length() == 0) {
            esc = Constants.DEFAULT_ESCAPE_CHAR;
        } else {
            esc = es.charAt(0);
        }
        return esc;
    }

    public void createIndexConditions(Session session, TableFilter filter) throws SQLException {
        if (regexp) {
            return;
        }
        if (!(left instanceof ExpressionColumn)) {
            return;
        }
        ExpressionColumn l = (ExpressionColumn) left;
        if (filter != l.getTableFilter()) {
            return;
        }
        // parameters are always evaluatable, but
        // we need to check the actual value now
        // (at prepare time)
        // otherwise we would need to prepare at execute time,
        // which is maybe slower (but maybe not in this case!)
        // TODO optimizer: like: check what other databases do
        if (!right.isValueSet()) {
            return;
        }
        if (escape != null && !escape.isValueSet()) {
            return;
        }
        String p = right.getValue(session).getString();
        Value e = escape == null ? null : escape.getValue(session);
        if (e == ValueNull.INSTANCE) {
            // should already be optimized
            throw Message.getInternalError();
        }
        initPattern(p, getEscapeChar(e));
        if (patternLength <= 0 || types[0] != MATCH) {
            // can't use an index
            return;
        }
        int dataType = l.getColumn().getType();
        if (dataType != Value.STRING && dataType != Value.STRING_IGNORECASE && dataType != Value.STRING_FIXED) {
            // column is not a varchar - can't use the index
            return;
        }
        int maxMatch = 0;
        StringBuffer buff = new StringBuffer();
        while (maxMatch < patternLength && types[maxMatch] == MATCH) {
            buff.append(pattern[maxMatch++]);
        }
        String begin = buff.toString();
        if (maxMatch == patternLength) {
            filter.addIndexCondition(new IndexCondition(Comparison.EQUAL, l, ValueExpression
                    .get(ValueString.get(begin))));
        } else {
            // TODO check if this is correct according to Unicode rules (code
            // points)
            String end;
            if (begin.length() > 0) {
                filter.addIndexCondition(new IndexCondition(Comparison.BIGGER_EQUAL, l, ValueExpression.get(ValueString
                        .get(begin))));
                char next = begin.charAt(begin.length() - 1);
                // search the 'next' unicode character (or at least a character
                // that is higher)
                for (int i = 1; i < 2000; i++) {
                    end = begin.substring(0, begin.length() - 1) + (char) (next + i);
                    if (compareMode.compareString(begin, end, ignoreCase) == -1) {
                        filter.addIndexCondition(new IndexCondition(Comparison.SMALLER, l, ValueExpression
                                .get(ValueString.get(end))));
                        break;
                    }
                }
            }
        }
    }

    public Value getValue(Session session) throws SQLException {
        Value l = left.getValue(session);
        if (l == ValueNull.INSTANCE) {
            return l;
        }
        if (!isInit) {
            Value r = right.getValue(session);
            if (r == ValueNull.INSTANCE) {
                return r;
            }
            String pattern = r.getString();
            Value e = escape == null ? null : escape.getValue(session);
            if (e == ValueNull.INSTANCE) {
                return ValueNull.INSTANCE;
            }
            initPattern(pattern, getEscapeChar(e));
        }
        String value = l.getString();
        boolean result;
        if (regexp) {
            // result = patternRegexp.matcher(value).matches();
            result = patternRegexp.matcher(value).find();
        } else {
            result = compareAt(value, 0, 0, value.length());
        }
        return ValueBoolean.get(result);
    }

    private boolean compare(String s, int pi, int si) {
        // TODO check if this is correct according to Unicode rules (code points)
        return compareMode.equalsChars(patternString, pi, s, si, ignoreCase);
    }

    private boolean compareAt(String s, int pi, int si, int sLen) {
        for (; pi < patternLength; pi++) {
            int type = types[pi];
            switch (type) {
            case MATCH:
                if ((si >= sLen) || !compare(s, pi, si++)) {
                    return false;
                }
                break;
            case ONE:
                if (si++ >= sLen) {
                    return false;
                }
                break;
            case ANY:
                if (++pi >= patternLength) {
                    return true;
                }
                while (si < sLen) {
                    if (compare(s, pi, si) && compareAt(s, pi, si, sLen)) {
                        return true;
                    }
                    si++;
                }
                return false;
            default:
                throw Message.getInternalError("type=" + type);
            }
        }
        return si == sLen;
    }

    /**
     * Test if the value matches the pattern.
     * 
     * @param pattern the pattern
     * @param value the value
     * @param escape the escape character
     * @return true if the value matches
     */
    public boolean test(String pattern, String value, char escape) throws SQLException {
        initPattern(pattern, escape);
        return compareAt(value, 0, 0, value.length());
    }

    private void initPattern(String p, char escape) throws SQLException {
        if (regexp) {
            patternString = p;
            try {
                if (ignoreCase) {
                    patternRegexp = Pattern.compile(p, Pattern.CASE_INSENSITIVE);
                } else {
                    patternRegexp = Pattern.compile(p);
                }
            } catch (PatternSyntaxException e) {
                throw Message.getSQLException(ErrorCode.LIKE_ESCAPE_ERROR_1, new String[]{p}, e);
            }
            return;
        }
        patternLength = 0;
        if (p == null) {
            types = null;
            pattern = null;
            return;
        }
        int len = p.length();
        pattern = new char[len];
        types = new int[len];
        boolean lastAny = false;
        for (int i = 0; i < len; i++) {
            char c = p.charAt(i);
            int type;
            if (escape == c) {
                if (i >= len - 1) {
                    throw Message.getSQLException(ErrorCode.LIKE_ESCAPE_ERROR_1, StringUtils.addAsterisk(p, i));
                }
                c = p.charAt(++i);
                if (c != '_' && c != '%' && c != escape) {
                    throw Message.getSQLException(ErrorCode.LIKE_ESCAPE_ERROR_1, StringUtils.addAsterisk(p, i));
                }
                type = MATCH;
                lastAny = false;
            } else if (c == '%') {
                if (lastAny) {
                    continue;
                }
                type = ANY;
                lastAny = true;
            } else if (c == '_') {
                type = ONE;
            } else {
                type = MATCH;
                lastAny = false;
            }
            types[patternLength] = type;
            pattern[patternLength++] = c;
        }
        for (int i = 0; i < patternLength - 1; i++) {
            if ((types[i] == ANY) && (types[i + 1] == ONE)) {
                types[i] = ONE;
                types[i + 1] = ANY;
            }
        }
        patternString = new String(pattern, 0, patternLength);
    }

    private boolean isFullMatch() {
        if (types == null) {
            return false;
        }
        for (int i = 0; i < types.length; i++) {
            if (types[i] != MATCH) {
                return false;
            }
        }
        return true;
    }

    public void mapColumns(ColumnResolver resolver, int level) throws SQLException {
        left.mapColumns(resolver, level);
        right.mapColumns(resolver, level);
        if (escape != null) {
            escape.mapColumns(resolver, level);
        }
    }

    public void setEvaluatable(TableFilter tableFilter, boolean b) {
        left.setEvaluatable(tableFilter, b);
        right.setEvaluatable(tableFilter, b);
        if (escape != null) {
            escape.setEvaluatable(tableFilter, b);
        }
    }

    public void updateAggregate(Session session) throws SQLException {
        left.updateAggregate(session);
        right.updateAggregate(session);
        if (escape != null) {
            escape.updateAggregate(session);
        }
    }

    public boolean isEverything(ExpressionVisitor visitor) {
        return left.isEverything(visitor) && right.isEverything(visitor)
                && (escape == null || escape.isEverything(visitor));
    }

    public int getCost() {
        return left.getCost() + right.getCost() + 3;
    }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人tv网| 在线观看日韩电影| 色婷婷亚洲精品| 日韩女优av电影在线观看| 欧美极品美女视频| 午夜激情一区二区| 97久久精品人人爽人人爽蜜臀| 欧美日韩精品电影| 日韩理论片网站| 国产主播一区二区三区| 欧美午夜寂寞影院| 综合在线观看色| 高清成人免费视频| 欧美精品一区男女天堂| 亚洲va韩国va欧美va精品| 91在线视频播放地址| 久久久久久久久岛国免费| 日本视频一区二区| 欧美日韩免费高清一区色橹橹| 国产精品夫妻自拍| 国产成人av电影| 国产亚洲一区字幕| 国产在线视频不卡二| 日韩视频一区二区三区在线播放| 亚洲午夜激情网站| 欧美三级视频在线| 一区二区三区日韩欧美| 91日韩在线专区| 精品亚洲国内自在自线福利| 日本精品裸体写真集在线观看 | 久久久久久久精| 秋霞午夜鲁丝一区二区老狼| 欧美精品三级在线观看| 一区二区三区影院| 欧美综合色免费| 亚洲国产成人tv| 欧美日韩亚洲不卡| 婷婷综合五月天| 欧美日韩国产三级| 日韩电影在线免费观看| 69久久99精品久久久久婷婷| 偷窥少妇高潮呻吟av久久免费 | 成人一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整| 国产在线精品不卡| 国产区在线观看成人精品| 国产91丝袜在线播放九色| 国产免费观看久久| 色综合色综合色综合| 一区二区三区小说| 91麻豆精品久久久久蜜臀 | 777亚洲妇女| 久久av资源网| 国产精品毛片久久久久久久| 色狠狠色噜噜噜综合网| 成人性视频免费网站| 中文字幕在线免费不卡| 欧美伊人久久久久久久久影院| 午夜私人影院久久久久| xvideos.蜜桃一区二区| 成人精品免费看| 亚洲国产欧美日韩另类综合| 日韩三级在线免费观看| 成人福利视频在线看| 亚洲电影第三页| 国产日韩av一区| 欧美私人免费视频| 国产精品一区二区三区乱码| 亚洲乱码国产乱码精品精可以看 | 亚洲人成在线播放网站岛国 | 欧美va在线播放| 99精品国产视频| 美女精品自拍一二三四| 亚洲欧美一区二区三区久本道91| 欧美久久久久久久久久| 成人网页在线观看| 奇米影视7777精品一区二区| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美视频你懂的| 成人黄色软件下载| 蜜桃传媒麻豆第一区在线观看| 一区在线播放视频| 婷婷六月综合网| 国产精品久久久久久久久免费相片 | 欧美午夜精品久久久久久孕妇| 久久99日本精品| 亚洲午夜影视影院在线观看| 国产女人18水真多18精品一级做| 欧美精品一二三四| 色综合色综合色综合| 国产福利不卡视频| 精品中文av资源站在线观看| 亚洲精品写真福利| 国产精品国产自产拍高清av | 欧美日韩精品欧美日韩精品一| 成人深夜视频在线观看| 精品无人码麻豆乱码1区2区 | 中文字幕高清一区| 日韩欧美一二区| 欧美精品免费视频| 欧美在线一区二区| 91黄视频在线| 91欧美激情一区二区三区成人| 国产一区二区精品久久| 六月婷婷色综合| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日本福利一区二区| av在线综合网| 成人精品免费看| 不卡的电影网站| fc2成人免费人成在线观看播放 | 视频一区在线播放| 亚洲成人免费影院| 午夜久久久影院| 亚洲影院久久精品| 亚洲成人精品在线观看| 亚洲网友自拍偷拍| 午夜精品久久久久| 日本成人中文字幕在线视频| 偷拍日韩校园综合在线| 喷水一区二区三区| 久久99久久99小草精品免视看| 麻豆精品蜜桃视频网站| 精品一二三四区| 大桥未久av一区二区三区中文| 国产成人免费视频网站 | 久久国产精品99久久久久久老狼 | 一区av在线播放| 亚洲电影一级片| 蜜臀av性久久久久蜜臀av麻豆| 麻豆91精品视频| 国产成人午夜99999| 91在线小视频| 欧美日本一区二区三区| 日韩欧美一区二区在线视频| 久久久久久久久99精品| 136国产福利精品导航| 一区二区三区四区蜜桃| 日韩av网站在线观看| 精品一区二区在线视频| 成人av资源下载| 欧美日韩在线观看一区二区| 日韩无一区二区| 国产精品国产馆在线真实露脸| 伊人色综合久久天天| 美女视频网站久久| www.欧美日韩| 制服视频三区第一页精品| 国产日韩欧美精品在线| 亚洲最色的网站| 国产美女精品人人做人人爽 | 3d动漫精品啪啪| 国产片一区二区三区| 亚洲在线视频网站| 欧美一区二区私人影院日本| 国产视频一区二区三区在线观看| 亚洲精品成人天堂一二三| 免费看黄色91| 在线亚洲人成电影网站色www| 日韩欧美久久一区| 一区二区三区波多野结衣在线观看| 欧美aaaaa成人免费观看视频| 国产91精品露脸国语对白| 69堂精品视频| 亚洲另类色综合网站| 国产福利不卡视频| 7777精品伊人久久久大香线蕉的 | 成人免费高清在线观看| 欧美精选午夜久久久乱码6080| 久久久精品蜜桃| 天堂资源在线中文精品| 91啪九色porn原创视频在线观看| 精品久久久久久久久久久院品网| 亚洲精品老司机| 成人午夜电影久久影院| 精品少妇一区二区三区视频免付费| 亚洲美腿欧美偷拍| 高清成人在线观看| 精品免费日韩av| 天堂资源在线中文精品| 在线观看欧美黄色| 国产精品萝li| 国产成人精品www牛牛影视| 欧美一二三区在线| 午夜成人免费视频| 日本乱人伦aⅴ精品| 亚洲欧洲日产国码二区| 国产精品亚洲成人| 欧美一区二区三区在线观看| 亚洲国产成人va在线观看天堂| 91一区在线观看| 国产精品黄色在线观看| 国v精品久久久网| 国产人伦精品一区二区| 国产一区二区精品在线观看| 日韩一二在线观看| 日韩精品久久理论片| 欧美一区二区三区四区高清| 天天操天天干天天综合网| 6080日韩午夜伦伦午夜伦|