最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle两个表连接的分段查询

来源:动视网 责编:小采 时间:2020-11-09 11:57:26
文档

Oracle两个表连接的分段查询

Oracle两个表连接的分段查询:Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_a Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_
推荐度:
导读Oracle两个表连接的分段查询:Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_a Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_


Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_a

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

文档

Oracle两个表连接的分段查询

Oracle两个表连接的分段查询:Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_a Select * From ( Select RowNum field_ByName,d.* From (SELECT b.*,c.loginaccount FROM JITUMS.TB_READERS b, JITUMS.tb_rd_
推荐度:
标签: 查询 连接 连接的
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top