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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hibernateworkflowstore.java

?? Java編譯osworkflow工作流系統的安裝和源代碼
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
    }    public List query(WorkflowExpressionQuery query) throws StoreException {        com.opensymphony.workflow.query.Expression expression = query.getExpression();        Criterion expr;        Class entityClass = getQueryClass(expression, null);        if (expression.isNested()) {            expr = buildNested((NestedExpression) expression);        } else {            expr = queryComparison((FieldExpression) expression);        }        //get results and send them back        Criteria criteria = session.createCriteria(entityClass);        criteria.add(expr);        try {            Set results = new HashSet();            Iterator iter = criteria.list().iterator();            while (iter.hasNext()) {                Object next = iter.next();                Object item;                if (next instanceof HibernateStep) {                    HibernateStep step = (HibernateStep) next;                    item = new Long(step.getEntryId());                } else {                    WorkflowEntry entry = (WorkflowEntry) next;                    item = new Long(entry.getId());                }                results.add(item);            }            return new ArrayList(results);        } catch (HibernateException e) {            throw new StoreException("Error executing query " + expression, e);        }    }    public List query(WorkflowQuery query) throws StoreException {        Class entityClass;        int qtype = query.getType();        if (qtype == 0) { // then not set, so look in sub queries            if (query.getLeft() != null) {                qtype = query.getLeft().getType();            }        }        if (qtype == WorkflowQuery.CURRENT) {            entityClass = HibernateCurrentStep.class;        } else {            entityClass = HibernateHistoryStep.class;        }        Criteria criteria = session.createCriteria(entityClass);        Criterion expression = buildExpression(query);        criteria.add(expression);        //get results and send them back        try {            Set results = new HashSet();            Iterator iter = criteria.list().iterator();            while (iter.hasNext()) {                HibernateStep step = (HibernateStep) iter.next();                results.add(new Long(step.getEntryId()));            }            return new ArrayList(results);        } catch (HibernateException e) {            throw new StoreException("Error executing query " + expression, e);        }    }    /**     * Returns an expression generated from this query     */    private Criterion getExpression(WorkflowQuery query) {        int operator = query.getOperator();        switch (operator) {        case WorkflowQuery.EQUALS:            return Expression.eq(getFieldName(query.getField()), query.getValue());        case WorkflowQuery.NOT_EQUALS:            return Expression.not(Expression.like(getFieldName(query.getField()), query.getValue()));        case WorkflowQuery.GT:            return Expression.gt(getFieldName(query.getField()), query.getValue());        case WorkflowQuery.LT:            return Expression.lt(getFieldName(query.getField()), query.getValue());        default:            return Expression.eq(getFieldName(query.getField()), query.getValue());        }    }    /**     * returns the correct name of the field given or "1" if none is found     * which matches the input.     * @param field     * @return     */    private String getFieldName(int field) {        switch (field) {        case FieldExpression.ACTION: // actionId            return "actionId";        case FieldExpression.CALLER:            return "caller";        case FieldExpression.FINISH_DATE:            return "finishDate";        case FieldExpression.OWNER:            return "owner";        case FieldExpression.START_DATE:            return "startDate";        case FieldExpression.STEP: // stepId            return "stepId";        case FieldExpression.STATUS:            return "status";        case FieldExpression.STATE:            return "state";        case FieldExpression.NAME:            return "workflowName";        case FieldExpression.DUE_DATE:            return "dueDate";        default:            return "1";        }    }    private Class getQueryClass(com.opensymphony.workflow.query.Expression expr, Collection classesCache) throws StoreException {        if (classesCache == null) {            classesCache = new HashSet();        }        if (expr instanceof FieldExpression) {            FieldExpression fieldExpression = (FieldExpression) expr;            switch (fieldExpression.getContext()) {            case FieldExpression.CURRENT_STEPS:                classesCache.add(HibernateCurrentStep.class);                break;            case FieldExpression.HISTORY_STEPS:                classesCache.add(HibernateHistoryStep.class);                break;            case FieldExpression.ENTRY:                classesCache.add(HibernateWorkflowEntry.class);                break;            default:                throw new QueryNotSupportedException("Query for unsupported context " + fieldExpression.getContext());            }        } else {            NestedExpression nestedExpression = (NestedExpression) expr;            for (int i = 0; i < nestedExpression.getExpressionCount(); i++) {                com.opensymphony.workflow.query.Expression expression = nestedExpression.getExpression(i);                if (expression.isNested()) {                    classesCache.add(getQueryClass(nestedExpression.getExpression(i), classesCache));                } else {                    classesCache.add(getQueryClass(expression, classesCache));                }            }        }        if (classesCache.size() > 1) {            throw new QueryNotSupportedException("Store does not support nested queries of different types (types found:" + classesCache + ")");        }        return (Class) classesCache.iterator().next();    }    /**     *  Recursive method for building Expressions using Query objects.     */    private Criterion buildExpression(WorkflowQuery query) throws StoreException {        if (query.getLeft() == null) {            if (query.getRight() == null) {                return getExpression(query); //leaf node            } else {                throw new StoreException("Invalid WorkflowQuery object.  QueryLeft is null but QueryRight is not.");            }        } else {            if (query.getRight() == null) {                throw new StoreException("Invalid WorkflowQuery object.  QueryLeft is not null but QueryRight is.");            }            int operator = query.getOperator();            WorkflowQuery left = query.getLeft();            WorkflowQuery right = query.getRight();            switch (operator) {            case WorkflowQuery.AND:                return Expression.and(buildExpression(left), buildExpression(right));            case WorkflowQuery.OR:                return Expression.or(buildExpression(left), buildExpression(right));            case WorkflowQuery.XOR:                throw new StoreException("XOR Operator in Queries not supported by " + this.getClass().getName());            default:                throw new StoreException("Operator '" + operator + "' is not supported by " + this.getClass().getName());            }        }    }    private Criterion buildNested(NestedExpression nestedExpression) throws StoreException {        Criterion full = null;        for (int i = 0; i < nestedExpression.getExpressionCount(); i++) {            Criterion expr;            com.opensymphony.workflow.query.Expression expression = nestedExpression.getExpression(i);            if (expression.isNested()) {                expr = buildNested((NestedExpression) nestedExpression.getExpression(i));            } else {                FieldExpression sub = (FieldExpression) nestedExpression.getExpression(i);                expr = queryComparison(sub);                if (sub.isNegate()) {                    expr = Expression.not(expr);                }            }            if (full == null) {                full = expr;            } else {                switch (nestedExpression.getExpressionOperator()) {                case NestedExpression.AND:                    full = Expression.and(full, expr);                    break;                case NestedExpression.OR:                    full = Expression.or(full, expr);                }            }        }        return full;    }    private Criterion queryComparison(FieldExpression expression) {        int operator = expression.getOperator();        switch (operator) {        case FieldExpression.EQUALS:            return Expression.eq(getFieldName(expression.getField()), expression.getValue());        case FieldExpression.NOT_EQUALS:            return Expression.not(Expression.like(getFieldName(expression.getField()), expression.getValue()));        case FieldExpression.GT:            return Expression.gt(getFieldName(expression.getField()), expression.getValue());        case FieldExpression.LT:            return Expression.lt(getFieldName(expression.getField()), expression.getValue());        default:            return Expression.eq(getFieldName(expression.getField()), expression.getValue());        }    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品在线免费播放| av亚洲精华国产精华| 337p亚洲精品色噜噜狠狠| 午夜久久久久久久久| 这里只有精品电影| 美女脱光内衣内裤视频久久影院| 欧美久久一区二区| 蜜桃一区二区三区在线观看| 精品少妇一区二区三区免费观看| 精品在线一区二区三区| 国产欧美一区二区精品婷婷| 成人a免费在线看| 亚洲国产日韩一区二区| 日韩视频在线一区二区| 国产成人免费在线观看| 亚洲欧美另类久久久精品2019| 欧美色图在线观看| 国内精品伊人久久久久影院对白| 国产精品午夜在线| 欧美日韩情趣电影| 黄页网站大全一区二区| 自拍偷拍亚洲欧美日韩| 欧美理论在线播放| 国产成人综合精品三级| 一区二区三区免费看视频| 欧美成人性福生活免费看| 成人开心网精品视频| 一区二区三区91| 欧美va亚洲va| 色狠狠综合天天综合综合| 日本欧美韩国一区三区| 国产精品久久一级| 91精品欧美久久久久久动漫| 成人av资源在线| 蜜桃av一区二区三区电影| 国产精品天天看| 日韩午夜精品视频| 色婷婷综合五月| 国产成人亚洲综合a∨猫咪| 亚洲综合色视频| 国产亚洲精品福利| 3d动漫精品啪啪一区二区竹菊| 成人免费毛片app| 午夜精品一区二区三区三上悠亚| 国产精品传媒视频| 久久综合色8888| 欧美日本在线播放| 91免费观看视频| 韩国欧美一区二区| 五月天久久比比资源色| 亚洲天堂久久久久久久| 国产亚洲一区二区三区四区| 制服丝袜中文字幕一区| 欧美视频一区在线观看| 99精品一区二区| 成人久久视频在线观看| 国产精品一区一区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 尤物视频一区二区| 亚洲男女毛片无遮挡| 国产精品无遮挡| 国产女主播在线一区二区| 精品国产乱码91久久久久久网站| 欧美区在线观看| 在线观看亚洲精品视频| 99riav久久精品riav| 福利91精品一区二区三区| 国产一区二区视频在线| 九九**精品视频免费播放| 日韩不卡手机在线v区| 午夜精品久久久久| 日韩影院在线观看| 日韩av网站在线观看| 石原莉奈在线亚洲二区| 污片在线观看一区二区| 午夜精品久久一牛影视| 日韩精品国产欧美| 奇米影视在线99精品| 青青草91视频| 国产一区二区三区在线看麻豆 | 国产精品久久久久一区二区三区共| 精品入口麻豆88视频| 精品国产乱子伦一区| 欧美一区二区三区不卡| 欧美一区二区三区公司| 欧美成人在线直播| 欧美va天堂va视频va在线| 久久久影院官网| 国产精品网站一区| 亚洲精品老司机| 性做久久久久久免费观看欧美| 午夜久久电影网| 精品一区二区三区香蕉蜜桃| 国产尤物一区二区| 成人av电影在线| 在线观看www91| 911精品国产一区二区在线| 欧美一个色资源| 久久久久国产一区二区三区四区| 国产精品三级av| 一区二区三区不卡视频在线观看| 天天综合天天做天天综合| 玖玖九九国产精品| 风流少妇一区二区| 91久久精品网| 日韩精品一区二区三区老鸭窝| 久久久亚洲精品石原莉奈| 日韩一区在线播放| 五月天一区二区| 国产乱人伦偷精品视频免下载| a亚洲天堂av| 欧美疯狂性受xxxxx喷水图片| 欧美zozozo| 亚洲精品亚洲人成人网在线播放| 亚洲成人综合视频| 国产一区二三区| 欧美曰成人黄网| 欧美精品一区二区在线观看| 日韩理论电影院| 免费一级欧美片在线观看| www.欧美精品一二区| 欧美精品18+| 国产亚洲精品aa午夜观看| 午夜久久久久久电影| 国产成人免费av在线| 91精品在线观看入口| 国产精品久99| 久久爱www久久做| 91国偷自产一区二区三区观看 | 欧美午夜精品理论片a级按摩| 精品国产一区二区亚洲人成毛片| 日韩美女视频19| 精品一区在线看| 欧美吻胸吃奶大尺度电影 | 极品美女销魂一区二区三区| 91久久精品一区二区| 中文文精品字幕一区二区| 日本v片在线高清不卡在线观看| av亚洲精华国产精华精| 久久先锋资源网| 婷婷成人综合网| 91麻豆精品视频| 欧美激情综合网| 国内精品在线播放| 日韩视频免费观看高清完整版在线观看| 国产精品不卡一区二区三区| 狠狠狠色丁香婷婷综合激情| 日韩视频在线一区二区| 日韩国产一二三区| 欧美三级三级三级爽爽爽| 伊人一区二区三区| 91网页版在线| 亚洲欧美一区二区三区孕妇| 粗大黑人巨茎大战欧美成人| 久久久美女毛片| 国产一区二区三区免费播放| 欧美成人综合网站| 韩国三级在线一区| 精品国产一区二区三区忘忧草 | 欧美天堂一区二区三区| 亚洲免费看黄网站| 91黄色免费观看| 亚洲一区二区三区四区五区中文| 在线一区二区视频| 亚洲伊人色欲综合网| 99re66热这里只有精品3直播| 国产午夜精品一区二区三区四区| 视频一区视频二区中文字幕| 在线电影一区二区三区| 亚洲激情第一区| 性欧美大战久久久久久久久| 欧美精品欧美精品系列| 亚洲福利一区二区| 欧美久久一二区| 日韩一区精品视频| 欧美二区在线观看| 精品一区二区免费在线观看| 日韩午夜在线观看| 日本中文字幕一区二区有限公司| 99综合影院在线| 中文字幕一区日韩精品欧美| 国产91清纯白嫩初高中在线观看| 91精品国产综合久久久蜜臀粉嫩 | 在线免费观看视频一区| 国产精品天美传媒沈樵| 国产精一区二区三区| 日韩欧美123| 美女视频黄免费的久久| 久久久国产一区二区三区四区小说 | 在线观看91精品国产入口| 亚洲午夜视频在线| 欧美日韩不卡一区二区| 偷拍亚洲欧洲综合| 日韩欧美高清在线| 国产91精品露脸国语对白| 国产精品久久久久久户外露出| 国产高清一区日本| 中文字幕在线一区免费| 欧美肥妇bbw| 国产一区二区三区四区五区美女|