2013-08-30 35 views
5

Mam pewne trudności próbuje uzyskać następujące do pracy w SQL Server:Jak ustawić SELECT NEXT VALUE na serwerze SQL?

CREATE TABLE table_X AS 
    SELECT 
     NEXT VALUE FOR GROUP_A AS GROUP_ID, RISK_ID 
    FROM 
     (SELECT UNIQUE RISK_ID, FROM table_Y) SS; 

Powiedziano mi:

"Incorrect syntax near the keyword 'SELECT'." 
"Incorrect syntax near the keyword 'UNIQUE'." 

Czym dokładnie jest problem i jak mogę to naprawić do pracy w SQL Server?

+1

Co chcesz zrobić? "create table jako" składnia nie jest składnią SQL Server. Używa 'select ... do', aby utworzyć tabelę z zapytania. –

+0

Czy mógłbyś wyjaśnić, co chcesz osiągnąć? – srid99

+0

'NASTĘPNA WARTOŚĆ DLA' http://technet.microsoft.com/en-us/library/ff878370.aspx –

Odpowiedz

11
CREATE TABLE Person 
(
FirstName Varchar(50), 
LastName Varchar(50) 
); 

/* 
Insert Some Values Into Person 
*/ 

CREATE SEQUENCE CountBy 
    START WITH 1 
    INCREMENT BY 1 ; 

SELECT NEXT VALUE FOR CountBy OVER (ORDER BY LastName) AS ListNumber, 
    FirstName, LastName 
    INTO table_x 
FROM Person 
+2

+1 - za dobrą odpowiedź. – Devart

1
SELECT 
    NEXT VALUE FOR GROUP_A AS GROUP_ID, SS.RISK_ID 
INTO 
    table_X 
FROM 
    (SELECT DISTINCT RISK_ID FROM table_Y) SS 
0

Spróbuj ten -

IF OBJECT_ID ('dbo.table_X') IS NOT NULL 
    DROP TABLE dbo.table_X 

SELECT RISK_ID --, ..... columns 
INTO dbo.table_X 
FROM ( 
    SELECT DISTINCT RISK_ID 
    FROM dbo.table_Y 
) SS 

SELECT * 
FROM dbo.table_X