在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

SQL Server中怎么改写内联表值函数

142次阅读
没有评论

共计 5454 个字符,预计需要花费 14 分钟才能阅读完成。

这篇文章主要讲解了“SQL Server 中怎么改写内联表值函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“SQL Server 中怎么改写内联表值函数”吧!

问题 SQL:

SELECT TOP 1001 ha.HuntApplicationID ,
 ha.PartyNumber ,
 mht.Name AS MasterHuntTypeName ,
 htly.LicenseYear ,
 lStatus.[Status] AS DrawTicketStatus ,
 isnull(dbo.udf_GetHuntApplicationPartyCount(ha.HuntApplicationID), 0) AS MemberCount ,
 count( won.DrawTicketLicenseID) AS DrawnMemberCount ,
 won.drawticketid ,
 dt.PreDrawNonResidentMemberCount AS NRMemberCount ,
 dbo.udf_GetAvgPreferencePoints(dt.DrawTicketID) AS PreferencePointAverage ,
 CASE
 WHEN ha.Quantity   1 THEN NULL
 ELSE dt.PreDrawRandomNumber
 END AS PreDrawRandomNumber ,
 dsm.Name AS DrawSelectionMethodName ,
 dt.DrawnSequence ,
 dt.PreferencePointRank ,
 dt.DrawID ,
 dt.RandomRank
FROM dbo.HuntApplication ha
JOIN dbo.HuntTypeLicenseYear htly ON ha.HuntTypeLicenseYearID = htly.HuntTypeLicenseYearID
JOIN dbo.MasterHuntType mht ON htly.MasterHuntTypeID = mht.MasterHuntTypeID
LEFT JOIN dbo.HuntApplicationLicense hal ON ha.HuntApplicationID = hal.HuntApplicationID
LEFT JOIN dbo.DrawTicket dt ON ha.HuntApplicationID = dt.HuntApplicationID
LEFT JOIN dbo.DrawTicketLicense won ON dt.DrawTicketID = won.DrawTicketID
AND won.WasDrawn = 1
LEFT JOIN dbo.DrawSelectionMethod dsm ON dt.DrawSelectionMethodID = dsm.DrawSelectionMethodID
LEFT JOIN dbo.StatusCode lStatus ON dt.StatusCodeID = lStatus.StatusCodeID
JOIN dbo.DrawTicketHuntChoice dthc ON dt.DrawTicketID = dthc.DrawTicketID
CROSS APPLY dbo.tvf_GetHuntApplicationPartyCount(ha.HuntApplicationID) hapc
CROSS APPLY dbo.tvf_GetAvgPreferencePoints(dt.DrawTicketID) app
WHERE 1 = 1
 AND htly.MasterHuntTypeID = @iMasterHuntTypeID
 AND htly.LicenseYear = @iLicenseYear
 AND dt.StatusCodeID = @iDrawTicketStatusCodeID
 AND dthc.WasDrawn = @iHuntChoiceWasDrawn
GROUP BY ha.HuntApplicationID,
 ha.PartyNumber,
 mht.[Name],
 htly.LicenseYear,
 lStatus.[Status],
 isnull(dbo.udf_GetHuntApplicationPartyCount(ha.HuntApplicationID), 0),
 won.DrawTicketID,
 dt.PreDrawNonResidentMemberCount,
 dbo.udf_GetAvgPreferencePoints(dt.DrawTicketID),
 CASE
 WHEN ha.Quantity   1 THEN NULL
 ELSE dt.PreDrawRandomNumber
 END,
 dsm.[Name],
 dt.DrawnSequence,
 dt.PreferencePointRank,
 dt.DrawID,
 dt.RandomRank
ORDER BY htly.LicenseYear DESC,
 mht.Name,
 lStatus.[Status],
 dt.DrawID,
 PreferencePointAverage DESC,
 PreDrawRandomNumber,
 ha.PartyNumber

静态函数:

CREATE FUNCTION [dbo].[udf_GetAvgPreferencePoints]
(@DrawTicketID INT)
RETURNS NUMERIC (18, 3)
BEGIN
 RETURN
 SELECT TOP 1
 CONVERT(DECIMAL, dt.PreDrawPreferencePointTotal) / NULLIF(CONVERT(DECIMAL, dt.PreDrawMemberCount),0)
 FROM dbo.DrawTicket dt
 WHERE dt.DrawTicketID = @DrawTicketID
END

执行时间 40s

这是典型可以进行静态函数改写内联表值函数的 sql:

改写后:

SELECT TOP 1001 ha.HuntApplicationID ,
 ha.PartyNumber ,
 mht.Name AS MasterHuntTypeName ,
 htly.LicenseYear ,
 lStatus.[Status] AS DrawTicketStatus ,
 --isnull(dbo.udf_GetHuntApplicationPartyCount(ha.HuntApplicationID), 0) AS MemberCount ,
  isnull(hapc.MemberCount, 0) AS MemberCount,
 count( won.DrawTicketLicenseID) AS DrawnMemberCount ,
 won.drawticketid ,
 dt.PreDrawNonResidentMemberCount AS NRMemberCount ,
 --dbo.udf_GetAvgPreferencePoints(dt.DrawTicketID) AS PreferencePointAverage ,
  app.PreferencePointAverage PreferencePointAverage,
 CASE
 WHEN ha.Quantity   1 THEN NULL
 ELSE dt.PreDrawRandomNumber
 END AS PreDrawRandomNumber ,
 dsm.Name AS DrawSelectionMethodName ,
 dt.DrawnSequence ,
 dt.PreferencePointRank ,
 dt.DrawID ,
 dt.RandomRank
FROM dbo.HuntApplication ha
JOIN dbo.HuntTypeLicenseYear htly ON ha.HuntTypeLicenseYearID = htly.HuntTypeLicenseYearID
JOIN dbo.MasterHuntType mht ON htly.MasterHuntTypeID = mht.MasterHuntTypeID
LEFT JOIN dbo.HuntApplicationLicense hal ON ha.HuntApplicationID = hal.HuntApplicationID
LEFT JOIN dbo.DrawTicket dt ON ha.HuntApplicationID = dt.HuntApplicationID
LEFT JOIN dbo.DrawTicketLicense won ON dt.DrawTicketID = won.DrawTicketID
AND won.WasDrawn = 1
LEFT JOIN dbo.DrawSelectionMethod dsm ON dt.DrawSelectionMethodID = dsm.DrawSelectionMethodID
LEFT JOIN dbo.StatusCode lStatus ON dt.StatusCodeID = lStatus.StatusCodeID
JOIN dbo.DrawTicketHuntChoice dthc ON dt.DrawTicketID = dthc.DrawTicketID
CROSS APPLY dbo.tvf_GetHuntApplicationPartyCount(ha.HuntApplicationID) hapc
CROSS APPLY dbo.tvf_GetAvgPreferencePoints(dt.DrawTicketID) app
WHERE 1 = 1
 AND htly.MasterHuntTypeID = @iMasterHuntTypeID
 AND htly.LicenseYear = @iLicenseYear
 AND dt.StatusCodeID = @iDrawTicketStatusCodeID
 AND dthc.WasDrawn = @iHuntChoiceWasDrawn
GROUP BY ha.HuntApplicationID,
 ha.PartyNumber,
 mht.[Name],
 htly.LicenseYear,
 lStatus.[Status],
 --isnull(dbo.udf_GetHuntApplicationPartyCount(ha.HuntApplicationID), 0),
  isnull(hapc.MemberCount, 0),
 won.DrawTicketID,
 dt.PreDrawNonResidentMemberCount,
 --dbo.udf_GetAvgPreferencePoints(dt.DrawTicketID),
  app.PreferencePointAverage,
 CASE
 WHEN ha.Quantity   1 THEN NULL
 ELSE dt.PreDrawRandomNumber
 END,
 dsm.[Name],
 dt.DrawnSequence,
 dt.PreferencePointRank,
 dt.DrawID,
 dt.RandomRank
ORDER BY htly.LicenseYear DESC,
 mht.Name,
 lStatus.[Status],
 dt.DrawID,
 PreferencePointAverage DESC,
 PreDrawRandomNumber,
 ha.PartyNumber

对应的表值函数:

CREATE FUNCTION [dbo].[tvf_GetAvgPreferencePoints]
(@DrawTicketID INT)
RETURNS TABLE WITH SCHEMABINDING
RETURN
 SELECT TOP 1
 CONVERT(DECIMAL, dt.PreDrawPreferencePointTotal) / NULLIF(CONVERT(DECIMAL, dt.PreDrawMemberCount),0) as PreferencePointAverage
 FROM dbo.DrawTicket dt
 WHERE dt.DrawTicketID = @DrawTicketID
GO

改写后执行时间从 40s 降低到 16s,对于倾斜列的优化速度更为明显

感谢各位的阅读,以上就是“SQL Server 中怎么改写内联表值函数”的内容了,经过本文的学习后,相信大家对 SQL Server 中怎么改写内联表值函数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-26发表,共计5454字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 男人先锋| 丰满少妇作爱视频免费观看 | 一出一进一爽一粗一大视频 | 九九热精 | 草伊人| 久久综合亚洲伊人色 | 成年人网站在线 | 永久在线观看 | 四虎国产精品免费久久 | 大伊香蕉在线精品不卡视频 | 国产精品久久久久久久久久98 | 色香欲综合成人免费视频 | 国产 麻豆 日韩 欧美 久久 | 99精品一区二区免费视频 | 一区二区三区乱码 | 麻豆精品人妻一区二区三区蜜桃 | 久久国产美女 | www在线看| 久久夜色精品国产 | 色噜噜狠狠色综合久夜色撩人 | 中文字幕人妻无码一区二区三区 | 自拍偷拍第3页 | 国产福利一区二区麻豆 | 国产裸模视频免费区无码 | 妇女性内射冈站hdwww000 | 爱爱小视频免费体验区在线观看 | 亚洲女同一区二区 | 亚洲网站免费 | 亚洲精品国偷拍自产在线麻豆 | 亚洲欧美一级久久精品 | 成人av片在线观看免费 | 欧美日韩三区 | 精品美女视频在线观看2023 | 一区二区视频在线观看 | 一级色| 国产精品无卡无在线播放 | 一久久| 国产精品1区 2区 3区 | 国产黄站| 麻豆入口视频在线观看 | 中文字幕无线码中文字幕免费 |