2017-04-26 17 views
0

with文を使用してビューを作成する方法は? 私はそれでエラーになっています:with文を使用してビューを作成する

WITH temp as (
select uu.email, u.logintime, u.region, p.id as panelid, p.panelname, p.numberofdownloads, dimensionType + ' (' + dimensionValue + ')' as filter 
from stat_users u 
left join stat_panels p 
on u.id=p.sessionid 
left join stat_filters f 
on p.id=f.panelid 
left join users uu 
on uu.id=u.userid 
where uu.Organization = 'name' AND 
    year(logintime) between 2015 and 2017 
    and panelname is not null 
) 


CREATE VIEW final as(
    select aa.email, aa.logintime, aa.region, aa.panelname, aa.numberofdownloads as downloads, case when len(aa.filters) > 0 then left(aa.filters, len(aa.filters)-1) else '' end as filters 
    from (
    Select distinct a.email, a.logintime, a.region, a.panelname, a.numberofdownloads, 
       (
        Select b.filter + ', ' AS [text()] 
        From temp b 
        Where b.panelid=a.panelid 
        ORDER BY b.panelid 
        For XML PATH ('') 
       ) filters 
    from temp a 
    ) aa 

) 私はこのようなエラーを取得しています:

> Incorrect syntax near the keyword 'CREATE'. 'CREATE VIEW' must be the 
> first statement in a query batch. 

だから、私はちょうど上の文WITHに基づいた選択使用してビューを作成して使用する必要がありますSQLサーバー2014

+0

はまた、私はエラーを取得しています: – mondayguy

答えて

1

はい、常にCREATEは、クエリ・バッチの最初のステートメントでなければなり

CREATE VIEW vFinal AS 
WITH Temp AS (
SELECT uu.email, u.logintime, u.region, p.id AS panelid, p.panelname, p.numberofdownloads, dimensionType + ' (' + dimensionValue + ')' AS Filter 
FROM stat_users u 
LEFT JOIN stat_panels p ON u.id=p.sessionid 
LEFT JOIN stat_filters f ON p.id=f.panelid 
LEFT JOIN users uu ON uu.id=u.userid 
WHERE uu.Organization = 'name' AND 
         YEAR(logintime) BETWEEN 2015 AND 2017 
         AND panelname IS NOT NULL 
) 
SELECT aa.email, aa.logintime, aa.region, aa.panelname, aa.numberofdownloads AS downloads, CASE WHEN LEN(aa.filters) > 0 THEN LEFT(aa.filters, LEN(aa.filters)-1) else '' end as filters 
    FROM (
    SELECT DISTINCT a.email, a.logintime, a.region, a.panelname, a.numberofdownloads, 
       (
        SELECT b.filter + ', ' AS [text()] 
        FROM temp b 
        WHERE b.panelid=a.panelid 
        ORDER BY b.panelid 
        FOR XML PATH ('') 
       ) filters 
    FROM temp a 
    ) aa 

GO 

構文句を選択するためのオプションの接頭辞であるCTE

CREATE VIEW View_Name AS 
WITH CTE_Name (Columns) AS (SELECT QUERY) 
SELECT QUERY using the CTE Table 
GO 
0
CREATE or replace VIEW final as 
    select aa.email, aa.logintime, aa.region, aa.panelname, aa.numberofdownloads as downloads, case when len(aa.filters) > 0 then left(aa.filters, len(aa.filters)-1) else '' end as filters 
    from (
    Select distinct a.email, a.logintime, a.region, a.panelname, a.numberofdownloads, 
       (
        Select b.filter + ', ' AS [text()] 
        From temp b 
        Where b.panelid=a.panelid 
        ORDER BY b.panelid 
        For XML PATH ('') 
       ) filters 
    from temp a) 
+0

それは – mondayguy

+0

どこに動作しない一時宣言ですか? – mondayguy

+0

ビューの一般的な構文... ビュービュー名を作成 として //選択したステートメント –

1

を使用してビュー表を作成する:

WITH query_name (column_name1, ...) AS 
    (SELECT ...) 

SELECT ... 

withがで使用される場合にも同様ですビュー:

CREATE VIEW ... 
WITH ... 
SELECT ... 
; 

も参照してください:私は、まずビューを作成置けばhttp://modern-sql.com/feature/with

関連する問題