- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
希望在 SQL (MS 2008 r2) 2 个相对简单的表中求和,虽然我正在努力寻找一种方法来使其工作,但我真的很感谢 SQL 专家的帮助:)
我将一个树型表连接到一个值集合,我们只检索值的最新实例(对于每个外键 x2),每个值都有一个创建日期,我们只需要创建日期之前的最新值。最后我们只想对树底部的值求和(即没有 child 的值)。我阅读了有关 CTE 的信息,并认为这是让它发挥作用的好方法,但之前没有这样做过,所以仍然在努力阅读我写的内容:)
我有一个相对简单的树表,称为节点
[id] [int] IDENTITY(1,1) NOT NULL,
[parentID] [int] NOT NULL
我感兴趣的这张表的数据是这样的。 (现实中的简单示例可能有 1000-2000 条记录,最多可能有 7 层嵌套,通常只有 3 或 4 层)ID + ParentID 始终是唯一的。
ID parentID
1077 1055
1110 1077
1103 1077
1104 1103
1105 1103
1111 1110
1112 1110
然后是我要加入的其他表 Allocations。
[Id] [int] IDENTITY(1,1) NOT NULL,
[creation] [datetime] NULL,
[crewId] [int] NULL,
[mealId] [int] NULL,
[allocation] [int] NULL
它是加入树的 crewId,它作为参数发送,因此我们将检索 1077 个 child 的总和。我只想包括无 child 值的总和。我想要 mealId 的每个值的总和。 crewId + mealId + creation 始终是唯一的。
Id creation crewId mealId allocation
----------- ----------------------- ----------- ----------- -----------
1 2012-04-13 16:50:00.000 1111 1085 1
2 2012-04-13 16:55:00.000 1111 1085 3
3 2012-04-13 17:03:31.100 1111 1085 2
4 2012-04-18 22:35:21.790 1112 1085 1
5 2012-04-18 22:35:32.630 1112 1086 1
6 2012-04-18 22:35:42.473 1112 1087 1
7 2012-04-25 18:15:53.117 1111 1086 1
8 2012-04-25 19:11:46.227 1111 1085 1
9 2012-04-25 19:11:46.227 1110 1085 5
这是我目前的情况,
declare @crewId int
set @crewId = 1077
-- get total of allocated to childless children
;with
Recurse as (
select
n.Id as DirectChildId
, n.Id
from umbracoNode n
where parentId = @crewId
union all
select
b.DirectChildId
, n.Id
from umbracoNode n
join Recurse b on b.Id = n.ParentId
)
select
n.DirectChildId, mealId, sum(a.Allocation) as TotalAllocation
from Recurse n
left join Allocations a on n.Id = a.crewId
and a.CrewId not in (select parentId from umbracoNode)
group by DirectChildId, mealId;
这几乎可行,但尚未考虑获取最新值。
我当前检索最新版本的查询如下所示。但我不知道如何将它们结合起来。
SELECT a.mealId, a.allocation
FROM Allocations AS a
LEFT OUTER JOIN Allocations AS a2
ON (a2.crewId = @crewId and a.MealId = a2.MealId AND a2.creation < a2.creation)
WHERE a.crewId = @crewId and a2.crewId IS NULL;
最佳答案
我让它工作了,这是我的答案:
ALTER PROCEDURE [dbo].[tegsGetTotalAllocated]
(@crewId As Integer)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
;with q as (
SELECT n.id
FROM umbracoNode n
WHERE n.id = @crewId
UNION ALL
SELECT n2.id
FROM umbracoNode n2
JOIN q
ON n2.parentId = q.id
)
SELECT
sum(a.allocation) as totalAllocated, a.mealId
FROM q
left join Allocation_Meal a on q.Id = a.crewId
and a.CrewId not in (select parentId from umbracoNode)
where mealId is not null
group by mealId
END
主要技巧是创建一个执行最新部分的 View 。我不太清楚这有什么影响。除了给我一种始终包含最新结果的虚拟表。这是否总是在每次命中时进行评估,还是比这更聪明?
CREATE VIEW [dbo].[Allocation_Meal]
AS
SELECT t1.mealId, t1.allocation, t1.crewId
FROM tegsAllocation AS t1
LEFT OUTER JOIN tegsAllocation AS t2
ON (t2.crewId = t1.crewId and t1.MealId = t2.MealId AND t1.creation < t2.creation)
WHERE t2.crewId IS NULL;
真的很感激任何关于它是否可以更有效率的想法或评论:)特别是我应该添加哪些索引来使这项工作更好,或者是识别这些索引的好方法:)
关于sql - t-sql Tree Join to Values 以获得仅限于最新数据的无子节点的总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10330050/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!