- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试了解 sql azure 中 WITH 语句的用法。我有一个初始查询,然后需要过滤 2 次。如果我只运行初始查询,它运行得很快。但是,一旦我添加了额外的过滤器,查询就会运行得很慢,永远不会完成,并且 azure force 会关闭连接。
所以,第一个 WITH 语句,它自己运行得非常快 ->
CREATE TYPE BrokerAccountAndTimeType as TABLE
(
[BrokerAccountId] [bigint],
[TimeUTC] [datetime]
);
GO
CREATE PROCEDURE [dbo].[GetLatestOpenBrokerAccountTradesByBrokerAccountAndTime]
@UserId [int],
@BrokerAccountAndTime BrokerAccountAndTimeType READONLY
AS
BEGIN
WITH trades as (SELECT bats.*
FROM BrokerAccountTrades bats
where bats.[TradeTimeUTC] = (SELECT MAX([TradeTimeUTC])
FROM BrokerAccountTrades bats2
inner join @BrokerAccountAndTime bat
on (bats.UserId = @UserId and bats2.BrokerAccountId = bat.BrokerAccountId)
WHERE bats2.UserId = bats.UserId
AND bats2.BrokerAccountId = bats.BrokerAccountId
AND bats2.SecurityId = bats.SecurityId
AND bats2.[TradeTimeUTC] < bat.TimeUTC))
select *
from trades
END
这不会造成问题 - 此查询在几秒钟内运行得足够快。但是,如果我随后添加额外的过滤,以从“交易”结果中获取我真正想要的记录,一切都会开始变得非常缓慢。这似乎违反直觉。如果 sql server 只是按顺序运行查询,就不会有问题,而且结果会很快返回。
CREATE PROCEDURE [dbo].[GetLatestOpenBrokerAccountTradesByBrokerAccountAndTime]
@UserId [int],
@BrokerAccountAndTime BrokerAccountAndTimeType READONLY
AS
BEGIN
--initial query
WITH trades as (SELECT bats.*
FROM BrokerAccountTrades bats
where bats.[TradeTimeUTC] = (SELECT MAX([TradeTimeUTC])
FROM BrokerAccountTrades bats2
inner join @BrokerAccountAndTime bat
on (bats.UserId = @UserId and bats2.BrokerAccountId = bat.BrokerAccountId)
WHERE bats2.UserId = bats.UserId
AND bats2.BrokerAccountId = bats.BrokerAccountId
AND bats2.SecurityId = bats.SecurityId
AND bats2.[TradeTimeUTC] < bat.TimeUTC)),
--filter the results from the 'trades' query
trades2 as (select t.*
FROM trades t
where t.ExternalId = (select max(ExternalId)
from trades t2
where t.userid = t2.userid
and t.brokeraccountid = t2.brokeraccountid
and t.securityid = t2.securityid))
--filter the results from the 'trades2' query
select t3.*
from trades2 t3
where t3.OpenClose = (select max(CONVERT(int,OpenClose))
from trades2 t4
where t4.userid = t3.userid
and t4.brokeraccountid = t3.brokeraccountid
and t4.securityid = t3.securityid)
and t3.NewPosition <> 0
END
有谁知道这里可能是什么问题?有没有办法强制查询按顺序运行?我可以只将第一个查询返回到我的代码并过滤掉代码中不需要的行,但这似乎是一个非常难看的修复。
仅供那些试图理解查询的人使用。这只是获取指定时间之前的最新记录,其中可以为正在查询的每个帐户提供不同的时间(因此是表值参数)。由于某些记录可能共享相同的时间戳,因此需要进一步过滤,因此有必要应用进一步过滤以确定共享相同时间戳的那些记录中哪些是“最新的”。
最佳答案
好的,所以我已经通过使用一个我觉得非常令人反感的表变量“解决”了这个问题。这意味着我必须在存储过程中重新定义现有表的模式,如果我需要修改它引用的表(例如添加新列等),这会造成必须更新此存储过程的维护负担。呸……
CREATE PROCEDURE [dbo].[GetLatestOpenBrokerAccountTradesByBrokerAccountAndTime]
@UserId [int],
@BrokerAccountAndTime BrokerAccountAndTimeType READONLY
AS
BEGIN
DECLARE @tempTrades TABLE
(
[Id] [bigint] NOT NULL PRIMARY KEY,
[UserId] [int] NOT NULL,
[BrokerAccountId] [bigint] NOT NULL,
[SecurityId] [tinyint] NOT NULL,
[TradeTimeUTC] [datetime] NOT NULL,
[OpenClose] [bit] NOT NULL,
--many more columns...
)
insert into @tempTrades
SELECT bats.*
FROM BrokerAccountTrades bats
where bats.[TradeTimeUTC] = (SELECT MAX([TradeTimeUTC])
FROM BrokerAccountTrades bats2
inner join @BrokerAccountAndTime bat
on (bats.UserId = @UserId and bats2.BrokerAccountId = bat.BrokerAccountId)
WHERE bats2.UserId = bats.UserId
AND bats2.BrokerAccountId = bats.BrokerAccountId
AND bats2.SecurityId = bats.SecurityId
AND bats2.[TradeTimeUTC] < bat.TimeUTC);
--filter the results from the 'trades' query
WITH trades2 as (select t.*
FROM @tempTrades t
where t.ExternalId = (select max(ExternalId)
from @tempTrades t2
where t.userid = t2.userid
and t.brokeraccountid = t2.brokeraccountid
and t.securityid = t2.securityid))
--filter the results from the 'trades2' query
select t3.*
from trades2 t3
where t3.OpenClose = (select max(CONVERT(int,OpenClose))
from trades2 t4
where t4.userid = t3.userid
and t4.brokeraccountid = t3.brokeraccountid
and t4.securityid = t3.securityid)
and t3.NewPosition <> 0
END
关于Azure : Very slow performance on WITH statement query,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26333477/
在 go lang 中使用“If with a short statement”有什么好处。引用:go tour if v := math.Pow(x, n); v < lim { retur
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
我有三个存储过程 Sp1、Sp2 和 Sp3。 第一个 (Sp1) 将执行第二个 (Sp2) 并将返回的数据保存到 @tempTB1 中,第二个将执行第三个 (Sp3) 并将数据保存到 @tempTB
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
PMD告诉我 A switch with less than 3 branches is inefficient, use a if statement instead. 这是为什么呢?为什么是3?他
我刚开始学习 Racket,所以我仍在努力弄清楚这门语言的复杂性。我正在尝试在列表中实现我自己的搜索功能。如果函数找到它,则返回索引,否则返回 -1。 (define (find-index list
在 Kotlin 中,您可以使用类似于三元运算符的 if 语句。 我们可以选择做这样的事情: val x = if (isOdd) 1 else 2 但是如果我们有多个变量需要根据某些条件进行设置,那
在我的 Android 应用程序中,我尝试使用 XMLPullParser 使用以下代码读取 xml 文件: while (eventType != XmlPullParser.END_DOCUMEN
这个问题已经有答案了: Boolean expressions in Java (8 个回答) 已关闭 7 年前。 我遇到过一些情况,其中第一个似乎改变了 boolean 值,而第二个却没有!两者之间
我基本上想做的是: select * from request where id = 1 and created_at like (today's date); 但使用 Eloquent 。 我试过:
我不确定为什么会收到此代码。基本上我希望能够动态定位我的发射器,但是当我添加一个选项来检查位置并根据需要进行纠正时,我不断收到此错误。 添加的代码是 if (
何时使用语句而不是准备语句。我想语句用于没有参数的查询,但为什么不使用准备好的语句呢?对于没有参数的查询,哪个更快。 最佳答案 I suppose statement is used in queri
我必须创建一个表,如下所示 借款人(客户编号,贷款编号) 如果客户没有超过 3 笔贷款,则可以贷款。 我创建的表如下 create table borrower( customerno int(5),
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicates: Is "else if" faster than "switch() case"? What is the
typescript 版本 2.2.2 我在我的 UserRoutzr.ts 中写了这个要求 const users = require(path.join(process.cwd() + "/da
我有一个用 JPQL 编写的应用程序,它可以命中非常不同的查询(在不同的资源上)。 对于很多此类查询,我需要知道结果总数(计数),因为我没有应用任何 LIMIT/OFFSET 由于此查询的性质非常不同
我对以下 Java 语句感到困惑: ArtClass artClass0 = new ArtClass(); int int3 = 73; boolean boolean0 = artClass0.f
我是一名优秀的程序员,十分优秀!