Oracle in查詢1000條限制的解決方案

前言

 項(xiàng)目使用批量粘貼excel的單號(hào)進(jìn)行查詢弹澎,因業(yè)務(wù)量大芽隆,查詢數(shù)量遠(yuǎn)超1000似袁,為解決Oracle的使用限制淋叶,提供以下解決方法,經(jīng)驗(yàn)證解決了使用限制雕拼、并且查詢高效纵东、穩(wěn)定、簡(jiǎn)單啥寇。

1. 首先要?jiǎng)?chuàng)建一張session級(jí)別的臨時(shí)表

create global temporary table CONDITIONS
(
  id    NUMBER,
  key   VARCHAR2(256),
  value VARCHAR2(256),
  attr1 VARCHAR2(256),
  attr2 VARCHAR2(256),
  attr3 VARCHAR2(256),
  attr4 VARCHAR2(256),
  attr5 VARCHAR2(256)
)
on commit preserve rows;
-- Create/Recreate indexes 
create index KEY_INDEX1 on CONDITIONS(KEY);
create index KEY_INDEX2 on CONDITIONS(ID);

2. 寫公用類

2.1. 定義一個(gè)javabean
package com.newkdd.common;
/**
 * 
 * @author MIKE
 *
 */
public class Conditions {
 
 private long id;// 毫秒級(jí)別的時(shí)間搓
 private String key;// 對(duì)應(yīng)數(shù)據(jù)庫(kù)的列名
 private String value;// 對(duì)應(yīng)key的value值
 private String attr1;// 備注1
 private String attr2;// 備注2
 private String attr3;// 備注3
 private String attr4;// 備注4
 private String attr5;// 備注5
 
 //此處省略get偎球、setter方法

}
2.2. 定義一個(gè)公用方法操作類
package com.newkdd.common;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 * 
 * @author MIKE
 *
 */
public class ConditionUtil {

 /**
  * 添加數(shù)據(jù)關(guān)聯(lián)條件
  * @param con 數(shù)據(jù)庫(kù)連接
  * @param conditions 條件集合
  * @return 影響的條數(shù)
  */
 public static int addCondition(Connection con, List<Conditions> conditions) {
  int result=0,count = 0;
  PreparedStatement pst = null;
  String sql = "insert into conditions(id,key,value,attr1,attr2,attr3,attr4,attr5) values(?,?,?,?,?,?,?,?)";
  try {
   pst = con.prepareStatement(sql);
   for (Conditions condition : conditions) {
    count++;
    result++;
    pst.setLong(1, condition.getId());
    pst.setString(2, condition.getKey());
    pst.setString(3, condition.getValue());
    pst.setString(4, condition.getAttr1());
    pst.setString(5, condition.getAttr2());
    pst.setString(6, condition.getAttr3());
    pst.setString(7, condition.getAttr4());
    pst.setString(8, condition.getAttr5());
    pst.addBatch();
    if (count > 600) {
     count=0;
     pst.executeBatch();
    }
   }
   if(count>0){
    pst.executeBatch();
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
  return result;
 }

 /**
  * 根據(jù)系統(tǒng)時(shí)間搓查詢當(dāng)前session的約束條件
  * @param con 數(shù)據(jù)庫(kù)連接
  * @param id 時(shí)間搓
  * @return 約束條件
  */
 public static List<Conditions> getConditions(Connection con, long id) {
  List<Conditions> conditions = new ArrayList<Conditions>();
  String sql = "select * from conditions t where t.id=?";
  PreparedStatement pst = null;
  try {
   pst = con.prepareStatement(sql);
   pst.setString(1, String.valueOf(id));
   ResultSet rs = pst.executeQuery();
   Conditions condition = null;
   while (rs.next()) {
    condition = new Conditions();
    condition.setId(rs.getLong("id"));
    condition.setKey(rs.getString("key"));
    condition.setValue(rs.getString("value"));
    condition.setAttr1(rs.getString("Attr1"));
    condition.setAttr2(rs.getString("Attr2"));
    condition.setAttr3(rs.getString("Attr3"));
    condition.setAttr4(rs.getString("Attr4"));
    condition.setAttr5(rs.getString("Attr5"));
    conditions.add(condition);
   }
  } catch (SQLException e) {
   e.printStackTrace();
  }
  return conditions;
 }
}

3. 使用表關(guān)聯(lián)替換‘in’操作

select * from table1 t1,conditions t2 where
  t1.column1=t2.value
  and t2.key='column1'
  and t2.id=''

現(xiàn)在在一個(gè)Session連接里邊就可以實(shí)現(xiàn)聯(lián)合查詢了,即解決了“in”的限制,又提升了查詢的速度辑甜。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末衰絮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子磷醋,更是在濱河造成了極大的恐慌猫牡,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件邓线,死亡現(xiàn)場(chǎng)離奇詭異淌友,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)骇陈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門震庭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人你雌,你說(shuō)我怎么就攤上這事归薛。” “怎么了匪蝙?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)习贫。 經(jīng)常有香客問(wèn)我逛球,道長(zhǎng),這世上最難降的妖魔是什么苫昌? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任颤绕,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘奥务。我一直安慰自己物独,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布氯葬。 她就那樣靜靜地躺著挡篓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪帚称。 梳的紋絲不亂的頭發(fā)上官研,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音闯睹,去河邊找鬼戏羽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛楼吃,可吹牛的內(nèi)容都是我干的始花。 我是一名探鬼主播,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼孩锡,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼酷宵!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起浮创,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤忧吟,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后斩披,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體溜族,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年垦沉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了煌抒。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡厕倍,死狀恐怖寡壮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情讹弯,我是刑警寧澤况既,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站组民,受9級(jí)特大地震影響棒仍,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜臭胜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一莫其、第九天 我趴在偏房一處隱蔽的房頂上張望癞尚。 院中可真熱鬧,春花似錦乱陡、人聲如沸浇揩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)胳徽。三九已至,卻和暖如春烙心,著一層夾襖步出監(jiān)牢的瞬間膜廊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工淫茵, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留爪瓜,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓匙瘪,卻偏偏與公主長(zhǎng)得像铆铆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子丹喻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法薄货,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法碍论,繼承相關(guān)的語(yǔ)法谅猾,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚_t_閱讀 31,599評(píng)論 18 399
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,805評(píng)論 0 11
  • 近期閱讀了一些網(wǎng)友寫的關(guān)于RabbitMq的文章鳍悠,整理下來(lái): 消息隊(duì)列的初認(rèn)識(shí):https://my.oschin...
    MORESIR閱讀 398評(píng)論 0 3
  • 今天我們班家長(zhǎng)研討關(guān)于早晨到校晨讀的問(wèn)題税娜。 關(guān)于晨讀這個(gè)事情我們家長(zhǎng)還是比較認(rèn)可的。早晨早來(lái)二十分鐘共...
    三一馬勝文爸爸閱讀 202評(píng)論 0 0
  • 這是什么鬼藏研?剛寫了幾百字敬矩,打了個(gè)盹,手指不知點(diǎn)了什么鍵蠢挡,驚醒之后手機(jī)上一片刺眼的白弧岳。崩潰了,今天就這樣吧业踏。
    王小唐閱讀 123評(píng)論 0 0