我正在将一些代码从ColdFusion迁移到.NET LinqToSQL。以下查询当前嵌入到ColdFusion中。我正在考虑编写一个存储过程,而不是试图让LinqToSQL。注意:此上下文中CF中的##实际上是SQL中的#。我不是在创建一个全局临时表
<cfquery name="qryTrafficDetails">
DECLARE @startDate date
DECLARE @endDate date
SET @startDate = <cfqueryparam cfsqltype="CF_SQL_date" value="#filter.StartDate#">
SET @endDate = <cfqueryparam cfsqltype="CF_SQL_date" value="#filter.endDate#">
SELECT CONVERT(date, CreateDate) AS CreateDate, url_vars.value('(search)[1]', 'nvarchar(max)') AS Item, remote_addr
INTO ##tempTraffic
FROM dbo.Traffic WITH (NOLOCK)
WHERE Createdate BETWEEN @startDate AND @endDate
AND url_vars.exist('.[search]') = 1
SELECT Area, AreaSort, Item, CalendarDate, isNull(Visitor, 0) AS Visitor, ISNULL(Hit,0) AS Hit
FROM dbo.Calendar LEFT JOIN
(
SELECT AreaSort = 10, 'Search' AS Area, FullGrid.Item AS Item, FullGrid.CalendarDate AS CreateDate,
COUNT(DISTINCT remote_addr) AS visitor,
COUNT(remote_addr) as hit
FROM (
SELECT DISTINCT CalendarDate, Item
FROM dbo.Calendar, ##TempTraffic
WHERE CalendarDate BETWEEN @startDate AND @endDate
) FullGrid
LEFT JOIN ##TempTraffic AS DataItem
ON FullGrid.CalendarDate = CreateDate
AND FullGrid.Item = DataItem.Item
GROUP BY FullGrid.Item, FullGrid.CalendarDate
) AS SummaryDetail
ON CalendarDate = SummaryDetail.CreateDate
WHERE CalendarDate BETWEEN @startDate AND @endDate
AND AreaSort IS NOT NULL
ORDER BY AreaSort, Item, CalendarDate
</cfquery>
<cfreturn qryTrafficDetails>
我关心的一些问题是:
答案 0 :(得分:1)
我不完全确定您的SQL代码的意图和动机,但似乎是一个摘要报告。在这种情况下,linq to sql可能不是理想的解决方案。
我认为你不能从linq 2 sql创建临时表。您可以创建子查询,也可以使用linq 2对象加入先前执行的查询的结果。
但我的建议是检查是否有更好的方法来查询数据,使用更简洁的查询,也可以在linq 2 sql上执行。
如果你真的需要这种查询,最好把它放在存储过程中。