<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-57  評論-117  文章-1  trackbacks-0

    處理oracle sql 語句in子句中(where id in (1, 2, ..., 1000, 1001)),如果子句中超過1000項就會報錯。
    這主要是oracle考慮性能問題做的限制。如果要解決次問題,可以用 where id (1, 2, ..., 1000) or id (1001, ...)

    /**
     * <b>function:</b> 處理oracle sql 語句in子句中(where id in (1, 2, ..., 1000, 1001)),如果子句中超過1000項就會報錯。
     * 這主要是oracle考慮性能問題做的限制。如果要解決次問題,可以用 where id (1, 2, ..., 1000) or id (1001, ...)
     * @author hoojo
     * @createDate 2012-8-31 下午02:36:03
     * @param ids in語句中的集合對象
     * @param count in語句中出現的條件個數
     * @param field in語句對應的數據庫查詢字段
     * @return 返回 field in (...) or field in (...) 字符串
     */
    private String getOracleSQLIn(List<?> ids, int count, String field) {
        count = Math.min(count, 1000);
        int len = ids.size();
        int size = len % count;
        if (size == 0) {
            size = len / count;
        } else {
            size = (len / count) + 1;
        }
        StringBuilder builder = new StringBuilder();
        for (int i = 0; i < size; i++) {
            int fromIndex = i * count;
            int toIndex = Math.min(fromIndex + count, len);
            //System.out.println(ids.subList(fromIndex, toIndex));
            String productId = StringUtils.defaultIfEmpty(StringUtils.join(ids.subList(fromIndex, toIndex), "','"), "");
            if (i != 0) {
                builder.append(" or ");
            }
            builder.append(field).append(" in ('").append(productId).append("')");
        }
        
        return StringUtils.defaultIfEmpty(builder.toString(), field + " in ('')");
    }


    作者:hoojo
    出處:
    blog:http://blog.csdn.net/IBM_hoojo
             http://hoojo.cnblogs.com
    本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。


    版權所有,轉載請注明出處 本文出自:
    分享道版權所有,歡迎轉載,轉載請注明出處,謝謝
    posted on 2012-08-31 14:51 hoojo 閱讀(5005) 評論(0)  編輯  收藏 所屬分類: DataBaseJavaEEJavaSEOracle
    主站蜘蛛池模板: 亚洲精品在线电影| 亚洲欧洲免费视频| 久久精品成人免费网站| 亚洲Av永久无码精品三区在线| 最近中文字幕免费完整| 亚洲免费一级视频| 亚洲av日韩精品久久久久久a | 国产成人高清亚洲| 99久久精品免费精品国产| 亚洲av片在线观看| 亚洲AV第一页国产精品| 日本免费v片一二三区| 久久国产精品免费专区| 亚洲成av人片在www鸭子| 亚洲国产精品SSS在线观看AV| 在线精品免费视频| 一级毛片aaaaaa免费看| 爱情岛亚洲论坛在线观看 | 亚洲成a人片在线不卡一二三区| 亚洲人成伊人成综合网久久久 | 亚洲网红精品大秀在线观看| 羞羞视频免费网站在线看| 亚洲精彩视频在线观看| 亚洲人成影院在线无码观看| 成人影片麻豆国产影片免费观看| 热久久这里是精品6免费观看| 欧洲 亚洲 国产图片综合| 亚洲免费视频在线观看| 亚洲精品一级无码中文字幕| 丁香花在线观看免费观看| 久久99精品免费视频| 免费视频精品一区二区| 亚洲综合小说另类图片动图| 亚洲激情在线视频| 亚洲精品第一国产综合精品99| 拨牐拨牐x8免费| 永久免费视频网站在线观看| 亚洲国产精品一区二区三区在线观看| 亚洲乱亚洲乱妇无码麻豆| 免费一级毛片在线播放| 歪歪漫画在线观看官网免费阅读|