我有这个快速查询,但由于我的表名为User(SQL关键字),Linqer(SQL到LINQ转换器)无法转换SQL查询。
以下是查询:
SELECT TOP (100) PERCENT
dbo.[User].OID,
dbo.[User].FirstName + ' ' + dbo.[User].LastName AS [User Name],
COUNT(dbo.AssignedCounty.OID) AS [Counties Assigned],
dbo.UserType.Name AS [User Type]
FROM
dbo.UserType
INNER JOIN dbo.[User] ON dbo.UserType.OID = dbo.[User].UserTypeID
LEFT OUTER JOIN dbo.AssignedCounty ON dbo.[User].OID = dbo.AssignedCounty.UserID
GROUP BY
dbo.[User].OID,
dbo.[User].FirstName + ' ' + dbo.[User].LastName,
dbo.UserType.Name,
dbo.[USER].IsActive
HAVING
(dbo.[User].IsActive = 1)
ORDER BY
[User Name]
任何人都可以指导我如何解决这个问题吗?我需要LINQ。
答案 0 :(得分:1)
显然,使用关键字作为表/列名称是一个非常坏的习惯。 User / Users是SQL Server中的关键字。此外,连接混乱,Linqer或SQL Metal无法处理它们,但LinqPad能够理解查询,但由于它不是转换工具,我没有好处。我终于进行了大规模的重命名操作,我的大多数失败的查询都开始重新开始工作了。用户 - > SystemUser