oracle内外链接混合用,混合在一起通过连接,内部连接和总结与Oracle

这里是我的设置:

我有2个表分别被称为“任务”和“时间表” “任务”表是递归的,这样每个任务可以有多个子任务。每个时间表都与一个任务相关联(不一定是“根”任务),并包含在其上工作的小时数。

实施例:

任务

ID:1 |名称:任务A | parent_id:NULL

id:2 |名称:任务A1 | parent_id:1

id:3 |名称:任务A1.1 | parent_id:2

id:4 |名称:任务B | parent_id:NULL

id:5 |名称:任务B1 | parent_id:4

次表

id:1 | task_id:1 |小时:1

id:2 | task_id:2 |小时:3

id:3 | task_id:3 |小时:1

id:5 | task_id:5 |时间:1 ...

我想做的事:

我想要一个查询,将返回一个“任务层次”工作的所有时间的总和。如果我们看一下前面的例子,这意味着我想得到以下结果:

任务A - 5小时|任务B - 1小时(S)

起初我想这

SELECT TaskName, Sum(Hours) "TotalHours"

FROM (

SELECT replace(sys_connect_by_path(decode(level, 1, t.name), '~'), '~') As TaskName,

ts.hours as hours

FROM tasks t INNER JOIN timesheets ts ON t.id=ts.task_id

START WITH PARENTOID=-1

CONNECT BY PRIOR t.id = t.parent_id

)

GROUP BY TaskName Having Sum(Hours) > 0 ORDER BY TaskName

它几乎工作。唯一的问题是,如果没有根任务的时间表,它将跳过整个时间表......但是可能有子时间表的时间表,而这正是在任务B1中发生的情况。我知道这是造成我的问题的“内部连接”部分,但我不知道我该如何摆脱它。

任何想法如何解决这个问题?

谢谢

2010-05-27

François

+0

我认为,如果你颠倒表的顺序,并使用左外连接,你会得到任务,即使没有时间片上,从而*威力*工作...也许? –

2010-05-27 15:04:27

+0

感谢您的帮助。在我的情况下进行左连接会导致一些主要的性能问题......即使表格索引良好,并且所有表格都是如此。 –

2010-05-27 15:30:47

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/288552.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

指针,指针函数,指针数组的区别

1、指针 #include<iostream> using namespace std;int main() {int a2;int *p;p&a;printf("%d\n",p);printf("%d\n",*p);return 0; }2、指针函数 #include<iostream> using namespace std;int *p(int a) {int *P;P&a;return P; } int …

python组件介绍_python 中的爬虫· scrapy框架 重要的组件的介绍

一 。 去重的规则组件去重数据&#xff0c;中通过set() 去重的&#xff0c; 留下的数据存在redis 中&#xff0c;找到这个类 &#xff1a; from scrapy.dupefilter import RFPDupeFiltera. 爬虫中yield Request(...dont_filterFalse)b. 类from scrapy.dupefilter import Base…

用java调用.net的wcf其实还是很简单的

前些天和我们的一个邮件服务商对接&#xff0c;双方需要进行一些通讯&#xff0c;对方是java团队&#xff0c;而作为.net团队的我们&#xff0c;只能公布出去的是一个wcf的basicbinding&#xff0c;想不 到问题来了&#xff0c;对方不知道怎么去调用这个basic&#xff0c;可能他…

php 使用PDO,防止sql注入 简单说明

PDO&#xff1a;php5 假如以下是一个简单的登录处理&#xff1a; 使用PDO连接mysql首先&#xff1a; 新建数据库 new PDO("mysql:hostlocalhost;dbnametest","root","root"); host:服务器 dbname:数据库名 后面两个分别是帐号和密码 默认…

DbTool 2.0.0 Released

DbTool 2.0.0 ReleasedIntroDbTool 一个支持 DbFirst、ModelFirst 和 CodeFirst 的数据库小工具。DbFirst 是根据数据库中的表信息生成代码中的 Model&#xff0c;以及生成数据表结构文档ModelFirst 是根据数据表信息或者数据表结构文档生成创建数据库的脚本CodeFirst 是指根据…

[蓝桥杯] 蚂蚁感冒

[蓝桥杯] 蚂蚁感冒 峰值内存消耗 < 256M  CPU消耗 < 1000ms 【题目描述 - Problem Description】 长100厘米的细长直杆子上有n只蚂蚁。它们的头有的朝左&#xff0c;有的朝右。 每只蚂蚁都只能沿着杆子向前爬&#xff0c;速度是1厘米/秒。 当两只蚂蚁碰面时&#xff0…

Source Insight之Relation Window Properties配置和一些快捷键

1 Source Insight之Relation Window Properties配置 我们先点击source Insight的这个地方 然后鼠标右键&#xff0c;点击Relation Window Properties&#xff0c;配置如下 2 快捷键 目前就我知道的 1&#xff09;按亮和按熄这个变量 shift F8 2&#xff09;跳转到具体一行…

ArcGIS 10.2 Calculate Value(Data Management) 工具的使用

1、概述 Calculate Value tool returns a value based on a specified Python expression. 计算值工具返回一个基于特定Python表达式的值。 工具位置:ToolBox→Data Management Tools→General→Calculate Value 2、注意事项 (1)该工具只能用于MoudleBuilder,而不能用于Py…

omnicppcomplete php,VIM 常用法 (三)

这里描述常用的插件。1. NERD tree快捷键&#xff1a;o 在已有窗口中打开文件&#xff0c;并跳到该窗口go 在已有窗口中打开目录或文件&#xff0c;但不跳到该窗口i/s 在split/vsplit的新窗口打开文件&#xff0c;并跳到该窗口gi/si 在split/vslpit的新窗口打开文件&#xff0c…

android:versionCode和android:versionName 用途

Android的版本可以在androidmainfest.xml中定义&#xff0c;主要有android:versionCode和android:versionNameandroid:versionCode:主要是用于版本升级所用&#xff0c;是INT类型的&#xff0c;第一个版本定义为1&#xff0c;以后递增&#xff0c;这样只要判断该值就能确定是否…

js 深复制一个对象

自定义 cloneObj 方法 //深复制对象 var cloneObj function (obj) {var newObj {};if (obj instanceof Array) {newObj [];}for (var key in obj) {var val obj[key];newObj[key] typeof val object ? cloneObj(val) : val;}return newObj; }; 转载于:https://www.cnblo…

js (javascript) 中获取年月日信息

获取年月日的所有信息&#xff1a; 直接使用date(); 如要取得 其他单独年月日时间 &#xff1a; 首先创建一个date对象&#xff0c;例如 &#xff1a; var d new Date(); 随后例如取得当前年 &#xff0c;使用&#xff1a; d.getFullYear() 当前月使用 &#xff1a; d…

vb6编写dll读取dat文件_【STM32Cube_15】使用硬件I2C读取温湿度传感器数据(SHT30)...

寻求更好的阅读体验&#xff0c;请移步Mculover666的个人博客&#xff1a;【STM32Cube_15】使用硬件I2C读取温湿度传感器数据&#xff08;SHT30&#xff09;​www.mculover666.cn本篇详细的记录了如何使用STM32CubeMX配置STM32L431RCT6的硬件I2C外设&#xff0c;读取SHT30温湿度…

windows之如何刷新电脑DNS缓存

1 问题 我在windows电脑里面的终端通过ping 泛域名&#xff0c;可以看到这个域名解析的地址&#xff0c;后面做了这个泛域名解析地址做了修改&#xff0c;但是我ping 这个泛域名地址的时候依然是之前的地址&#xff0c;然后我把终端关闭掉&#xff0c;再次ping这个地址&#x…

tcp/ip ---数据封装过程

转载于:https://www.cnblogs.com/saryli/p/5306721.html

NuGet 新特性 -- 中心化的 NuGet 包版本管理

NuGet 新特性 -- 中心化的 NuGet 包版本管理IntroNuGet 支持了一个可以中心化管理 NuGet 包版本的方案&#xff0c;我们可以在一个地方统一管理 NuGet 包的版本Preface在之前的版本中我们通常在每个指定包版本引用的地方会设置 NuGet 包的版本号&#xff0c;如果项目比较多&…

Java面向对象编程学习

1、新建一个工程&#xff0c;在工程下新建一个类Method01&#xff08;勾选创建main函数&#xff09; package ClassStudy;class Person {String name; //默认为nullint age; //默认为0//构造函数public Person(){namenull;age0;}//方法public void say(){System.out.println(&…

数据库oracle 别名不能更新,数据库oracle改成mysql后Hibernate不能使用别名问题

报错&#xff1a; [INFO ] 11:34:19.272 [http-apr-7081-exec-8] org.hibernate.type.StringType - could not read column value from result set: PK_ID; Column PK_ID not found. [WARN ] 11:34:19.274 [http-apr-7081-exec-8] o.h.util.JDBCExceptionReporter - SQL Error:…

sql 两表更新

UPDATE sale_origin_line set statecancel from sale_origin p,sale_origin_line q where p.idq.order_id and p.company_id3 and p.date<2017-08-01;转载于:https://www.cnblogs.com/1314520xh/p/7338592.html

查询工资最低的3名员工的职工工号、姓名和收入_普法课堂|你有多久没有收到工资条了?...

工资条对于现在的大多数劳动者而言&#xff0c;尤其是90、00后&#xff0c;可能是一个十分陌生的概念和事物&#xff0c;许多用人单位已经不再向劳动者发放&#xff0c;在司法实践中工资条越来越少的在庭审中予以呈现。工资条对于劳动者而言十分重要&#xff0c;即便未有用人单…