是否可以将视图编写为SQL Server中的表?

时间:2010-12-08 23:24:47

标签: sql-server sql-server-2005

在“脚本到”选项下,您可以选择脚本创建为您想要的任何内容。有没有办法使用类似的方法为视图获取匹配的表结构?

5 个答案:

答案 0 :(得分:37)

没有开箱即用。您可以从视图中SELECT INTO创建一个新的空表,然后使用常用的SSMS方法将其编写为CREATE TABLE

SELECT TOP 0 * INTO NewTable FROM YourView

如果这是问题的动机,这可能会节省一些打字。

答案 1 :(得分:9)

以下是我们用来执行此操作的内容。

下面的所有信用都发布在帖子here和@Zanlok上,其修订后的版本I已被使用并且被推荐用于查看视图而不是表格:



    SELECT 
        t.TABLE_CATALOG,
        t.TABLE_SCHEMA,
        t.TABLE_NAME,
        'create table '+QuoteName(t.TABLE_SCHEMA)+'.' + QuoteName(so.name) + ' (' + LEFT(o.List, Len(o.List)-1) + ');  ' 
            + CASE WHEN tc.Constraint_Name IS NULL THEN '' 
              ELSE 
                'ALTER TABLE ' + QuoteName(t.TABLE_SCHEMA)+'.' + QuoteName(so.name) 
                + ' ADD CONSTRAINT ' + tc.Constraint_Name  + ' PRIMARY KEY ' + ' (' + LEFT(j.List, Len(j.List)-1) + ');  ' 
              END as 'SQL_CREATE_TABLE'
    FROM sysobjects so

    CROSS APPLY (
        SELECT 
              '  ['+column_name+'] ' 
              +  data_type 
              + case data_type
                    when 'sql_variant' then ''
                    when 'text' then ''
                    when 'ntext' then ''
                    when 'decimal' then '(' + cast(numeric_precision as varchar) + ', ' + cast(numeric_scale as varchar) + ')'
                  else 
                  coalesce(
                    '('+ case when character_maximum_length = -1 
                        then 'MAX' 
                        else cast(character_maximum_length as varchar) end 
                    + ')','') 
                end 
            + ' ' 
            + case when exists ( 
                SELECT id 
                FROM syscolumns
                WHERE 
                    object_name(id) = so.name
                    and name = column_name
                    and columnproperty(id,name,'IsIdentity') = 1 
              ) then
                'IDENTITY(' + 
                cast(ident_seed(so.name) as varchar) + ',' + 
                cast(ident_incr(so.name) as varchar) + ')'
              else ''
              end 
            + ' ' 
            + (case when IS_NULLABLE = 'No' then 'NOT ' else '' end) 
            + 'NULL ' 
            + case when information_schema.columns.COLUMN_DEFAULT IS NOT NULL THEN 'DEFAULT '+ information_schema.columns.COLUMN_DEFAULT 
              ELSE '' 
              END 
            + ','  -- can't have a field name or we'll end up with XML

        FROM information_schema.columns 
        WHERE table_name = so.name
        ORDER BY ordinal_position
        FOR XML PATH('')
    ) o (list)

    LEFT JOIN information_schema.table_constraints tc on  
        tc.Table_name = so.Name
        AND tc.Constraint_Type  = 'PRIMARY KEY'

    LEFT JOIN information_schema.tables t on  
        t.Table_name = so.Name

    CROSS APPLY (
        SELECT QuoteName(Column_Name) + ', '
        FROM information_schema.key_column_usage kcu
        WHERE kcu.Constraint_Name = tc.Constraint_Name
        ORDER BY ORDINAL_POSITION
        FOR XML PATH('')
    ) j (list)

    WHERE
        xtype = 'V'
        AND name NOT IN ('dtproperties')
        -- AND so.name = 'ASPStateTempSessions'
    ;

答案 2 :(得分:2)

如果已安装,则可以使用SQL Server导入和导出向导。将源和目标设置为同一服务器,源是视图,目标是新表。这将从视图中获取列定义,并使用这些定义创建一个新表。

明显的缺点是新表将包含旧视图中的数据,如果视图中有大量行,则可能会出现问题。最简单的方法是创建一个带有视图定义的空白表,选择选项"写一个查询来指定要传输的数据"在wizare中使用这样的代码:

SELECT * FROM YourView WHERE 1=2

由于1不等于2,因此不会返回任何行,但会保留列定义,并且将使用该定义创建新表。

希望有所帮助!

答案 3 :(得分:1)

如果您的意思是根据View定义中选择的列生成CREATE TABLE语句,我不知道没有任何方法可以在没有中间步骤的情况下执行此操作,例如@Martin建议的内容。

答案 4 :(得分:0)

如果您有权访问SSIS,请插入数据流。对于来源,请使用您的视图。对于目的地,请使用新表。将使用列和数据类型生成整个表。如果您不想传输数据,可以保留原样。单击“是”以保存数据流时,您的表已经创建。现在,如果您希望查看刚刚生成的新表的列名和数据类型,可以转到SSMS并生成脚本。