Oracle兩個表串連的分段查詢

來源:互聯網
上載者:User

Select * From ( Select RowNum field_ByName,d.* From  (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_account c where b.reader_id= c.reader_id) d  Where RowNum <= 10 ) A  Where A.field_ByName >= 1;

 Select * From ( Select RowNum field_ByName,b.* From ( SELECT c.name cname,d.loginaccount,e.name  FROM JITUMS.TB_READERS c ,jitums.tb_rd_account d,jitums.tb_rd_type e where  c.rdtypecode= e.rdtypecode and c.reader_id= d.reader_id ) b Where RowNum <= 10 ) A  Where A.field_ByName > 0 

三個表串連,其中兩個表裡有一列名字相同,得重新命名c.name cnam

一般在項目開發的時候會經常用到,大批量資料不可能一次性載入到記憶體,這就會用到分頁,分頁就用到範圍我是做.net的微軟跟隨者(呵呵,不要有分歧哦!Java和.net在這個行業的口舌之戰還未停休),時候也用Oracle你說的這個範圍查詢在Sql Server裡可能要好實現些,因為它有個Top關鍵字.這個就不說了,主要是說Oracle.Oracle 有個Rownum關鍵字它的功能等同於SqlServer的Top,Rownum返回的是Table的內部行號,查尋有多少條記錄,它的行號就會從1一直遞增到最後一條記錄,而且這個遞增是即時的.所以我們不能用常規的思想去查詢.
例如:Select * From TableName Where RowNum >=1000 And RowNum <= 10000  因為記錄還沒有產生,你給的條件根本不起作用,所以為空白.但有個解決方案,我們可能做個子查詢,讓RowNum變成能用的資料
Select RowNum field_ByName,table_ByName.* From TableName table_ByName然後嵌入到下面括弧
Select * from ( Select RowNum field_ByName,table_ByName.* From TableName table_ByName ) A  Where A.field_ByName >= 1000 And A.field_ByName <= 10000 上面這個方法好理解,
但效率不高,它查詢了所有資料,然後從所有資料查詢到1000到10000之間的行,根據笛卡爾積原理,冗餘相當大.還有種方法對上面Sql進行了改進,效率高很多
Select * From ( Select RowNum field_ByName,table_ByName.* From TableName table_ByName  
Where RowNum <= 10000 ) A  Where A.field_ByName >= 1000

還可以寫為:

SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM JITUMS.TB_READERS ) A WHERE ROWNUM <=10  WHERE RN > 0

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.