在“脚本到”选项下,您可以选择脚本创建为您想要的任何内容。有没有办法使用类似的方法为视图获取匹配的表结构?
答案 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并生成脚本。