oracle子查询问题,急急急!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle子查询问题,急急急!相关的知识,希望对你有一定的参考价值。

然后出现了2个问题,一:子查询使用order by直接报错,二:因为排序取第一行要经过2层封装(select a from (select a from order by) where rownum = 1),然后导致再与外层表关联时提示字段无效!!
具体的一条Sql如下:
select a.1,b.1,c.1,(select d.1 from (select d.1 from table_D d where d.1 = a.1 order by d.2) where rownum = 1) from table_A a,table_B b,table_C c where ...;
不想创建function,不然每次遇到这样的查询都新建一个太烦了
各位大神请拉到本地具体看看,子查询主要管理的字段太多了,又可能不存在值,如果直接放到最外层使4个表关联,那我其他想要查的字段都可能查不到了

又发现一个奇怪的问题,一条普通的使用order by的查询语句可以直接执行,但是用()将这条sql括起来直接报错了,missing right parenthesis

参考技术A select a.1,b.1,c.1,
(select d.1 from
(select d.1,rownum from table_D d where d.1 = a.1 order by d.2) where rownum = 1)
from table_A a,table_B b,table_C c where ...;

在最里边加一个字段rownum就OK了追问

应该不是这个问题,我不套用2层直接使用order by也会报错

追答

我只是解决你rownum报错的问题,你写的语句就像一个不太懂sql的人写的,我也不明白你为什么非要套两层,还有你的表结构也不清楚

参考技术B 1 使用order by的时候 order by 的条件是什么,select 后面就必须要包含 这个条件,所以
select d.1,d.2 from table_D d where d.1 = a.1 order by d.2

2. 作用域问题,而且你的查询语句可读性差效率也不行,四个表的关联关系完全没有体现出来,如果没关联关系查出来做什么用,这SQL不知道你是要做什么追问

首先这条子查询单独拿出来是可以执行的,放入子查询就不行了,order by不是group by,不用前后字段对应;然后,我的意图主要是关联3个表取这些表中的数据,但是其中只有一个字段是在第4个表中的,会关联外面2个表,关联的结果可能没有值,所以不能直接将这个表放到外面直接关联4个表

追答

select a.1,b.1,c.1,d from table_A a,table_B b,table_C c ,(select d.1 from (select d.1 from table_D d where d.1 = a.1 order by d.2) where rownum = 1) d;

把子查询放后面去

追问

嗯,order by 的问题解决了,用括号将order by语句括起来后,必须在外面括号后加别名才行,但是这里作用域的问题还是没解决,子查询里用不了a.1

追答

我晕,你把条件放后面就行了啊
select a.1,b.1,c.1,d from table_A a,table_B b,table_C c ,(select * from table_D d order by d.2 where rownum = 1) d where d.1 = a.1

追问

你把2层的子查询变成1层了,这样不能实现先排序后取值的,但是假如排序的字段是主键的话好像可以实现,反正我这样的不行。不过还是谢谢你的解答了,我再研究研究!

Qt 绘图问题,急急急!

请问如何在一个QWidget子类原有区域画一条直线而不擦除该区域。好实现么?

参考技术A

为了能够使用Qt开发图形绘制软件,首先应该掌握Qt的坐标系统。在Qt中,通过QPainter类来控制它的坐标系统。连同QPaintDevice类与QPaintEngine类,QPainter类构成了Qt绘图系统的基础。其中,QPainter用于执行绘图的操作;QPaintDevice是对一块二维空间的抽象,在这块空间上,我们可以使用QPainter进行图形的绘制;QPaintEngine提供了在不同的设备上进行绘图的接口。

QPaintDevice类是能够进行绘图的对象的基类,QWidget,QPixmap,QPicture,QImage,以及QPrinter类继承了QPaintEngine类的绘图能力。绘图设备的缺省坐标系统是以左上角作为原点,x坐标向右递增,y坐标向下递增。单位对于不同的设备是不同的,在基于像素的设备上,以一个像素作为缺省单位,而在打印机上,以1/72英寸作为缺省单位。

在编写图形绘制软件时,我们需要进行逻辑坐标与物理坐标之间的转换,这部分功能由QPainter的转换矩阵,视口,以及窗口来实现。缺省情况下,逻辑坐标与物理坐标是一致的。QPainter也支持平移与旋转这样的坐标变换。

图元的尺寸(宽度与高度)总是对应于它的数学模型,并且会忽略它所使用的笔的宽度。下图是通过两个点来实现矩形和直线的例子,用到的代码为:

追问

大哥,你不累吗?

追答

发错了吗?

参考技术B 用双缓存机制。本回答被提问者采纳 参考技术C 不很明白你的意思,在QWidget的子类上画图,如果你事先不擦除,它就是在上面覆盖的呀

以上是关于oracle子查询问题,急急急!的主要内容,如果未能解决你的问题,请参考以下文章

oracle 查询的sql语句特别慢,是啥原因,是or特别慢吗,用啥优化,急急急!!!

急急急,Sql查询一个字段是不是存在某一个值,怎么写查询语句?

oracle简单编程问题,在线等 急急急!大大悬赏

急急急,在线等!solr4.10结合oracle增量导入数据问题!

sql子查询(急100分)

急急急!access 数据库对两个表关联count