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

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

?? hibernateworkflowstore.java

?? 一個很好實用的工作流OSWORKFLOW開發(fā)例子.有著非常優(yōu)秀的靈活性.
?? 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| av男人天堂一区| 日日摸夜夜添夜夜添国产精品 | 国产视频一区在线播放| 蜜桃一区二区三区四区| 1000部国产精品成人观看| 经典一区二区三区| 亚洲精品菠萝久久久久久久| 欧美电影免费观看高清完整版在线 | 亚洲午夜久久久久久久久电影院| 日韩欧美aaaaaa| 91在线高清观看| 黄网站免费久久| 婷婷夜色潮精品综合在线| 国产精品美女一区二区在线观看| 91精品欧美福利在线观看 | 欧美美女黄视频| a在线播放不卡| 国产一区二区精品久久91| 亚洲va天堂va国产va久| 中文字幕日韩av资源站| 国产婷婷精品av在线| 91精品福利在线一区二区三区| 97国产一区二区| 国产成人综合亚洲91猫咪| 蜜桃视频一区二区三区在线观看| 一级中文字幕一区二区| 日韩一区日韩二区| 日本一二三四高清不卡| 日韩欧美中文字幕一区| 欧美日韩在线一区二区| 91黄色在线观看| 91捆绑美女网站| 成人精品国产一区二区4080| 国产精品18久久久久久久网站| 日韩制服丝袜av| 亚洲成人免费看| 亚洲亚洲人成综合网络| 亚洲免费资源在线播放| 中文字幕色av一区二区三区| 亚洲国产精品成人久久综合一区| 精品少妇一区二区三区免费观看 | 亚洲第一会所有码转帖| 洋洋成人永久网站入口| 亚洲日本一区二区| 亚洲人成网站在线| 一区二区在线看| 亚洲综合在线免费观看| 一区二区三区精品在线观看| 亚洲综合色丁香婷婷六月图片| 亚洲欧美aⅴ...| 亚洲男同1069视频| 亚洲高清不卡在线| 日韩一区精品字幕| 免费精品视频在线| 国内精品久久久久影院色| 国模娜娜一区二区三区| 国产成人在线视频网站| 成人精品国产免费网站| 色噜噜狠狠色综合中国| 欧美日韩国产另类不卡| 欧美一区二区在线免费播放 | 精品动漫一区二区三区在线观看| 欧美成人三级在线| 国产日韩欧美a| 自拍偷在线精品自拍偷无码专区| 亚洲裸体在线观看| 日韩高清国产一区在线| 麻豆91免费看| 国产乱理伦片在线观看夜一区| 成人免费视频免费观看| 日本韩国视频一区二区| 在线播放中文一区| 精品三级在线看| 国产精品你懂的在线欣赏| 亚洲免费av网站| 奇米色一区二区| 国产91富婆露脸刺激对白| 一本大道久久精品懂色aⅴ| 欧美日韩一级片网站| 久久这里只精品最新地址| 亚洲手机成人高清视频| 午夜精品福利在线| 国产精品一二三四| 欧美一a一片一级一片| 日韩一级高清毛片| 中文字幕制服丝袜成人av| 婷婷丁香激情综合| 高清在线观看日韩| 欧美精品三级在线观看| 欧美激情一区二区三区| 亚洲成人激情自拍| 夫妻av一区二区| 欧美精品色一区二区三区| 中文字幕av在线一区二区三区| 亚洲国产一区二区a毛片| 国产一区二区精品在线观看| 欧洲一区在线电影| 国产日韩精品一区二区三区 | 亚洲品质自拍视频| 另类的小说在线视频另类成人小视频在线 | 欧美乱熟臀69xxxxxx| 亚洲国产精品成人久久综合一区| 日韩影视精彩在线| 91丨国产丨九色丨pron| 精品国产欧美一区二区| 中文字幕在线观看不卡| 欧美群妇大交群中文字幕| 亚洲美女免费视频| 在线一区二区视频| 精彩视频一区二区| 久久久精品天堂| 欧美在线视频不卡| 国产精品欧美经典| 美美哒免费高清在线观看视频一区二区| 国产伦精品一区二区三区免费迷| 欧美猛男超大videosgay| 中文字幕中文字幕一区| 激情综合网激情| 日本久久一区二区| 26uuuu精品一区二区| 久久精品国产亚洲高清剧情介绍| 不卡av电影在线播放| 日韩一级大片在线观看| 亚洲啪啪综合av一区二区三区| 一区二区三区不卡视频在线观看| 成人妖精视频yjsp地址| 欧美一区二区免费视频| 亚洲女性喷水在线观看一区| 精品一区免费av| 欧美麻豆精品久久久久久| 亚洲综合色网站| 久久综合九色综合欧美亚洲| 精品美女一区二区| 国产欧美日韩三级| 国产精品一区三区| 91精品国产91久久久久久一区二区 | 555夜色666亚洲国产免| 亚洲视频免费在线| 国产精品2024| 欧美刺激脚交jootjob| 午夜久久电影网| 国产成人av电影在线播放| 久久久亚洲精华液精华液精华液| 日本视频一区二区三区| 欧美日韩另类国产亚洲欧美一级| 中文字幕中文字幕一区二区| 国产一区视频网站| 中文字幕乱码久久午夜不卡 | 一个色妞综合视频在线观看| 蜜桃视频在线观看一区二区| 欧美久久久一区| 一区二区三区中文字幕精品精品| 91丨porny丨中文| 中文字幕制服丝袜一区二区三区| 国产aⅴ综合色| 国产日韩欧美精品综合| 国产精品一线二线三线精华| 中文av一区特黄| 丁香一区二区三区| 国产日韩欧美一区二区三区综合| 国产精品一级在线| 国产亚洲午夜高清国产拍精品 | 成人禁用看黄a在线| 欧美激情艳妇裸体舞| 精品一区二区在线看| 国产精品视频九色porn| 成人av在线一区二区三区| 中文字幕在线观看不卡视频| 成人激情免费网站| 亚洲久本草在线中文字幕| 欧美日韩大陆一区二区| 日韩av不卡一区二区| 精品少妇一区二区三区免费观看 | 成人在线综合网| 亚洲最新视频在线观看| 欧美色男人天堂| 日韩高清不卡一区| 精品少妇一区二区三区日产乱码 | 亚洲视频免费观看| 欧美色手机在线观看| 亚洲午夜视频在线观看| 久久亚洲综合色一区二区三区| 国产精品亚洲综合一区在线观看| 国产精品免费网站在线观看| 91欧美一区二区| 一片黄亚洲嫩模| 91精品国产综合久久福利软件 | 丝袜诱惑制服诱惑色一区在线观看| 欧美日韩国产a| 韩国v欧美v日本v亚洲v| 久久久久久久久久久黄色| 色综合天天性综合| 日韩综合小视频| 久久日一线二线三线suv| 成人aa视频在线观看| 一区二区三区精品视频| 国产丝袜美腿一区二区三区| 色国产精品一区在线观看|