EnVisageOnline/Main-RMO/Database/Scripts/20151027/02_VW_ProjectAccessByUser_R...

53 lines
1.2 KiB
Transact-SQL

USE [EnVisage]
GO
/****** Object: View [dbo].[VW_ProjectAccessByUser] Script Date: 10/26/2015 11:41:16 AM ******/
DROP VIEW [dbo].[VW_ProjectAccessByUser]
GO
/****** Object: View [dbo].[VW_ProjectAccessByUser] Script Date: 10/26/2015 11:41:16 AM ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE VIEW [dbo].[VW_ProjectAccessByUser] AS
select A.*, B.UserId,
ISNULL(C.Name, '') AS StatusName, ISNULL(D.Name, '') AS CompanyName, ISNULL(E.Name, '') AS ClientName,
ISNULL(F.Name, '') AS TypeName, G.Id AS ActiveScenarioId, ISNULL(G.Name, '') AS ActiveScenarioName,
ISNULL(
(
STUFF((SELECT ',' + t.Name AS [text()]
FROM dbo.Team2Project t2p
JOIN dbo.Team t
ON t2p.TeamId = t.Id
WHERE t2p.ProjectId = A.Id
ORDER BY t.Name ASC
FOR XML PATH('')), 1, 1, '')
), '') AS Teams,
B.[Read], B.Write from Project A
INNER JOIN VW_ProjectAccess B ON (B.ProjectId = A.Id)
LEFT JOIN [Status] C ON (C.Id = A.StatusId)
LEFT JOIN Company D ON (D.Id = A.CompanyId)
LEFT JOIN Client E ON (E.Id = A.ClientId)
LEFT JOIN [Type] F ON (F.Id = A.TypeId)
LEFT JOIN Scenario G ON (G.ParentId = A.Id) AND (G.[Type] = 2) AND (G.[Status] = 1) -- Poftfolio scenario & active
WHERE (B.[Read] = 1) OR (B.Write = 1)
GO