2013-08-30 12 views
5

Sto avendo qualche difficoltà cercando di ottenere il seguente a lavorare in SQL Server:Come rendere SELECT NEXT VALUE funziona in SQL Server?

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; 

Mi si dice:

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

Che cosa è esattamente il problema e come posso risolvere questo problema al lavoro in SQL Server?

+1

Cosa stai cercando di fare? La sintassi 'create table as' non è la sintassi di SQL Server. Usa 'select ... into' per creare una tabella da una query. –

+0

potresti spiegare cosa vuoi ottenere? – srid99

+0

'VALORE SUCCESSIVO PER' http://technet.microsoft.com/en-us/library/ff878370.aspx –

risposta

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 - per la buona risposta. – 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

provare questo -

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 
Problemi correlati