已经很久没用使用这个脚本了,今天用到,并做修改,增加了生成扩展属性功能。

Go
if object_ID('[up_CreateTable]') is not null
Drop Procedure [up_CreateTable]
Go
/* 生成建表脚本(V4.0) Andy 2017-3-28 */
Create Proc up_CreateTable
(
@objectList nvarchar(max)=null
)
as
--With ENCRYPTION /* 参数说明:
@objectList 对象列表,对象之间使用","隔开 存储过程生成的建表脚本,包含Column,Constraint,Index,extended_properties Modify: andy 2017-3-28 增加了扩展属性
*/
Set Nocount On
Declare @sql nvarchar(max),
@objectid int,
@id int,
@Rowcount int,
@ObjectName sysname,
@Enter nvarchar(2),
@Tab nvarchar(2) Select @Enter=Char(13)+Char(10),
@Tab=Char(9) Declare @Tmp Table(name sysname) If @objectList>''
Begin
Set @sql='Select N'''+Replace(@objectList,',',''' Union All Select N''')+''''
Insert Into @Tmp (name) Exec(@sql) Set @sql=null
Select @sql=Isnull(@sql+',','')+name
From @Tmp As a
Where Not Exists(Select 1 From sys.objects Where type='U' And name=a.name) If @sql>''
Begin
Set @sql='发现无效的表名: '+@sql
Raiserror (50001,-1,-1, @sql)
Return(1) End
End If object_id('tempdb..#Objects') Is Not Null
Drop Table #Objects If object_id('tempdb..#Columns') Is Not Null
Drop Table #Columns Create Table #Objects(id int Identity(1,1) Primary Key,object_id int,name sysname) ;With t As
(
Select Object_id,Convert(int,0) As LevelNo,name As object_name
From sys.objects a
Where Type='U' And is_ms_shipped=0 And Not Exists(Select 1 From sys.foreign_keys Where referenced_object_id=a.object_id)
Union All
Select a.referenced_object_id As Object_id,b.LevelNo+1 As LevelNo,c.name As object_name
From sys.foreign_keys a
Inner Join t b On b.object_id=a.parent_object_id
Inner Join sys.objects c On c.object_id=a.referenced_object_id And c.is_ms_shipped=0
where a.referenced_object_id<>a.parent_object_id
)
Insert Into #Objects(object_id,name)
Select a.object_id,object_name
From t a
Where Not Exists(Select 1 From t Where object_id=a.object_id And LevelNo>a.LevelNo) And
Not Exists(Select 1 From sys.extended_properties Where major_id=a.object_id And minor_id=0 And class=1 And Name=N'microsoft_database_tools_support')
And (Exists(Select 1 From @Tmp Where name=a.object_name) Or Not Exists(Select 1 From @Tmp))
Group By object_id,object_name,LevelNo
Order By LevelNo Desc Set @Rowcount=@@Rowcount
If @Rowcount=0
Begin
-- Raiserror 50001 N'没有可以生产脚本的表!'
Raiserror (50001,-1,-1, N'没有可以生产脚本的表!')
Return(1)
End --Column
Select a.object_id,
a.column_id As Seq,
Cast(1 As tinyint) As DefinitionType,
Quotename(a.name)+Char(32)+ c.name +
Case
When a.user_type_id In (231,239) Then '('+Case a.max_length When -1 Then 'Max' Else Rtrim(a.max_length/2) End +')'
When a.user_type_id In (62,165,167,173,175) Then '('+Case a.max_length When -1 Then 'Max' Else Rtrim(a.max_length) End+')'
When a.user_type_id In (106,108) Then '('+Rtrim(a.[precision])+','+Rtrim(a.scale)+')'
Else ''
End
+ Char(32)+
Case a.is_rowguidcol When 1 Then 'Rowguidcol ' Else '' End +
Case a.is_identity When 1 Then 'Identity('+Cast(d.seed_value As nvarchar(10))+','+Cast(d.increment_value As nvarchar(10))+') ' Else '' End+
Case a.is_nullable When 1 Then 'Null ' Else 'Not Null ' End+
Isnull('Constraint '+Quotename(e.name)+' Default('+e.definition+')','') As definition Into #Columns
From sys.columns As a
Inner Join #Objects As b On b.object_id=a.object_id
Inner Join sys.types As c On c.user_type_id=a.user_type_id
Left Outer Join sys.identity_columns As d On d.object_id=a.object_id And d.column_id=a.column_id And a.is_identity=1
Left Outer Join sys.Default_constraints As e On e.object_id=a.default_object_id And e.parent_column_id=a.column_id Create Nonclustered Index IX_#Columns_object_id On #Columns(object_id Asc) --Constraint
Insert Into #Columns Select a.parent_object_id As object_id,
Row_number() Over(Partition By a.parent_object_id Order By Case a.type When 'PK' Then 1 When 'C' Then 2 Else 3 End)As Seq,
2 As DefinitionType,
'Alter Table '+Quotename(object_name(a.parent_object_id)) +' Add Constraint '+Quotename(a.name)+
Case a.type
When 'PK' Then ' Primary Key '+Case When Exists(Select 1 From sys.indexes Where object_id=a.parent_object_id And is_primary_key=1 And type=1) Then N'Clustered ' Else N'Nonclustered ' End+
'('+Stuff((Select ','+Quotename(c1.Name)+Case a1.is_descending_key When 1 Then ' Desc' Else ' Asc' End
From sys.index_columns As a1
Inner Join sys.indexes As b1 On b1.object_id=a1.object_id And b1.index_id=a1.index_id And b1.is_primary_key=1
Inner Join sys.columns As c1 On c1.object_id=a1.object_id And c1.column_id=a1.column_id
Where a1.object_id=a.parent_object_id
For Xml Path('')
),1,1,'')+
')'
When 'F' Then ' Foreign Key ('+Stuff((Select ','+Quotename(b1.Name)
From sys.foreign_key_columns As a1
Inner Join sys.columns As b1 On b1.object_id=a1.parent_object_id And b1.column_id=a1.parent_column_id
Where a1.constraint_object_id=a.object_id
Order By a1.constraint_column_id
For Xml Path('')
),1,1,'')+
') References '+(Select Quotename(object_name(referenced_object_id)) From sys.foreign_keys Where object_id=a.object_id)+
' ('
+Stuff((Select ','+Quotename(b1.Name)
From sys.foreign_key_columns As a1
Inner Join sys.columns As b1 On b1.object_id=a1.referenced_object_id And b1.column_id=a1.referenced_column_id
Where a1.constraint_object_id=a.object_id
Order By a1.constraint_column_id
For Xml Path('')
),1,1,'')+
')'
When 'UQ' Then ' Unique'+(Select Case a1.type When 1 Then ' Clustered' Else ' Nonclustered' End
From sys.indexes As a1
Where a1.object_id=a.parent_object_id
And Exists(Select 1 From sys.key_constraints Where object_id=a.object_id And parent_object_id=a1.object_id And unique_index_id=a1.index_id)
)+
'('+Stuff((Select ','+Quotename(c1.Name)+Case a1.is_descending_key When 1 Then ' Desc' Else ' Asc' End
From sys.index_columns As a1
Inner Join sys.indexes As b1 On b1.object_id=a1.object_id And b1.index_id=a1.index_id And b1.is_unique_constraint=1
Inner Join sys.columns As c1 On c1.object_id=a1.object_id And c1.column_id=a1.column_id
Where a1.object_id=a.parent_object_id
And Exists(Select 1 From sys.key_constraints Where object_id=a.object_id And parent_object_id=a1.object_id And unique_index_id=a1.index_id)
For Xml Path('')
),1,1,'')+
')'
When 'C' Then ' Check' +(Select definition From sys.check_constraints Where object_id=a.object_id)
Else ''
End As definition From sys.objects As a
Where a.type In('PK','F','C','UQ')
And Exists(Select 1 From #Objects Where object_id=a.parent_object_id) --Index
Insert Into #Columns
Select a.object_id ,
a.index_id As Seq,
3 As DefinitionType,
'Create '+Case a.is_unique When 1 Then 'Unique ' Else '' End+
Case a.type When 1 Then 'Clustered ' Else 'Nonclustered ' End+
'Index '+Quotename(a.name)+' On '+Quotename(b.name)+
' ('+Stuff((Select ','+Quotename(b1.Name)+Case a1.is_descending_key When 1 Then ' Desc' Else ' Asc' End
From sys.index_columns As a1
Inner Join sys.columns As b1 On b1.object_id=a1.object_id And b1.column_id=a1.column_id
Where a1.object_id=a.object_id And a.index_id=a1.index_id And a1.is_included_column=0
For Xml Path('')
),1,1,'')+
')'+
Isnull(' Include('+Stuff((Select ','+Quotename(b1.Name)
From sys.index_columns As a1
Inner Join sys.columns As b1 On b1.object_id=a1.object_id And b1.column_id=a1.column_id
Where a1.object_id=a.object_id And a.index_id=a1.index_id And a1.is_included_column=1
For Xml Path('')
),1,1,'')+
')','')
As definition
From sys.indexes As a
Inner Join #Objects As b On b.object_id=a.object_id
Where a.type>0
And Not Exists(Select 1 From sys.key_constraints Where parent_object_id=a.object_id And unique_index_id=a.index_id) --extended_properties Andy 2017-3-28 添加扩展属性
insert into #Columns
select b.object_id,
a.major_id as Seq,
4 as DefinitionType,
case a.minor_id
when 0 then 'execute sp_addextendedproperty ''MS_Description'','''+convert(nvarchar(max),a.value)+''', ''user'', ''dbo'', ''table'', '+quotename(b.name,'''')
else 'execute sp_addextendedproperty ''MS_Description'','''+convert(nvarchar(max),a.value)+''', ''user'', ''dbo'', ''table'', '+quotename(b.name,'''')+',''column'','+quotename(c.name,'''')
end
from sys.extended_properties a
inner join #Objects b on b.object_id=a.major_id
inner join sys.columns c on c.object_id=b.object_id
and c.column_id=a.minor_id
where a.class=1 --Print /*
Print 'Use '+Quotename(db_name())+@Enter+'Go'+@Enter+'/* 创建表结构 Andy '+Convert(nvarchar(10),Getdate(),120)+'*/'+@Enter Set @id=1
While @id<=@Rowcount
Begin
Select @objectid=object_id,@ObjectName=name From #Objects Where id=@id Set @Sql=@Enter+'--('+Rtrim(@id)+'/'+Rtrim(@Rowcount)+') '+@ObjectName+@Enter+'If object_id('''+Quotename(@ObjectName)+''') Is Null'+@Enter+'Begin'+@Enter+@Tab+
'Create Table '+Quotename(@ObjectName)+@Enter+@Tab+'('+@Enter
Select @Sql=@Sql+@Tab+@Tab+definition+','+@Enter
From #Columns
Where object_id=@objectid
And DefinitionType=1
Group By Seq,definition
Order By Seq
Set @sql=Substring(@sql,1,Len(@sql)-3)+@Enter+@Tab+')'+@Enter
Select @Sql=@Sql+@Tab+definition+@Enter
From #Columns
Where object_id=@objectid
And DefinitionType>1
Group By DefinitionType,Seq,definition
Order By Seq Print Substring(@sql,1,Len(@sql)-2)+@Enter+'End'
Set @id=@id+1
End */
--Modify Nr:20100510 Start
Declare @MaxRow int if object_id('tempdb..#Print') Is Not Null
Drop Table #Print Create Table #Print(Row int Identity(1,1) Primary Key,Sql nvarchar(4000)) Print 'Use '+Quotename(db_name())+@Enter+'Go'+@Enter+'/* 创建表结构 Andy '+Convert(nvarchar(10),Getdate(),120)+'*/'+@Enter Set @id=1
While @id<=@Rowcount
Begin
Select @objectid=object_id,@ObjectName=name From #Objects Where id=@id Insert Into #Print(Sql)
Select @Enter+'--('+Rtrim(@id)+'/'+Rtrim(@Rowcount)+') '+@ObjectName+@Enter+'If object_id('''+Quotename(@ObjectName)+''') Is Null'+@Enter+'Begin'+@Enter+@Tab+
'Create Table '+Quotename(@ObjectName)+@Enter+@Tab+'('+@Enter Insert Into #Print(Sql)
Select @Tab+@Tab+definition+','+@Enter
From #Columns
Where object_id=@objectid
And DefinitionType=1
Group By Seq,definition
Order By Seq Set @MaxRow=Scope_identity()
Update #Print
Set Sql=Substring(sql,1,Len(sql)-3)+@Enter+@Tab+')'+@Enter
Where Row=@MaxRow Insert Into #Print(Sql)
Select @Tab+definition+@Enter
From #Columns
Where object_id=@objectid
And DefinitionType>1
Group By DefinitionType,Seq,definition
Order By Seq if @@ROWCOUNT >0
Set @MaxRow=Scope_identity() Update #Print
Set Sql= Substring(Sql,1,Len(Sql)-2)+@Enter+'End'
Where Row=@MaxRow Set @id=@id+1
End Set @id=1
While @id>0
Begin
Set @sql=''
Select @sql=sql From #Print Where row=@id If @sql>''
Begin
Print @sql
Set @id=@id+1
end
Else
Set @id=0
End --Modify Nr:20100510 End Print 'Go' Drop Table #Columns
Drop Table #Objects Go

生成建表脚本up_CreateTable的更多相关文章

  1. SQL SERVER 生成建表脚本

    /****** Object: StoredProcedure [dbo].[GET_TableScript_MSSQL] Script Date: 06/15/2012 11:59:00 ***** ...

  2. (转)SQL SERVER 生成建表脚本

    https://www.cnblogs.com/champaign/p/3492510.html /****** Object: StoredProcedure [dbo].[GET_TableScr ...

  3. SQL SERVER 生成MYSQL建表脚本

    /****** Object: StoredProcedure [dbo].[GET_TableScript_MYSQL] Script Date: 06/15/2012 13:05:14 ***** ...

  4. SQL SERVER 生成ORACLE建表脚本

    /****** Object: StoredProcedure [dbo].[GET_TableScript_ORACLE] Script Date: 06/15/2012 13:07:16 **** ...

  5. PowerDesigner生成的ORACLE 建表脚本中去掉对象的双引号,设置大、小写

    原文:PowerDesigner生成的ORACLE 建表脚本中去掉对象的双引号,设置大.小写 若要将 CDM 中将 Entity的标识符都设为指定的大小写,则可以这么设定: 打开cdm的情况下,进入T ...

  6. powerdesigner中将表的name在生成建表sql时生成注释

    1.为powerdesigner的表设置注释方法: powerdesigner默认没有注释: 设置方法: 选择那个表 右键- >Properties- >Columns- >Cust ...

  7. sqlserver 表中记录生成insert,可以加条件,可以生成建表语句

    sqlserver 表中记录生成insert,可以加条件,可以生成建表语句 create PROCEDURE [sp_getinsert] ( ) , --如果非默认架构,可以加上架构名 例如:sch ...

  8. 【SQL】ORACLE在sqlplus中使用spool方式生成建表语句

    在实际生产中有时我们需要将一张表的数据导入到另外一张表,如果有PLSQL,我们可以通过PLSQL工具将数据导出为sql脚本,然后再在另外一个数据库中执行这个脚本.但有时在实际生产中我们没有PLSQL这 ...

  9. MySql 建库建表脚本

    1.建库 CREATE DATABASE test DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; 2.建表脚本 CREATE TABLE `c ...

随机推荐

  1. Django之url路由

    Django之url路由 url路由介绍 url路由是关联url及其视图函数关系的过程. 作用就是使views里面处理数据的函数与请求的url建立映射关系 url路由配置 Django的url路由配置 ...

  2. java接口签名(Signature)实现方案

    预祝大家国庆节快乐,赶快迎接美丽而快乐的假期吧!!! 一.前言 在为第三方系统提供接口的时候,肯定要考虑接口数据的安全问题,比如数据是否被篡改,数据是否已经过时,数据是否可以重复提交等问题.其中我认为 ...

  3. java date HHmmss hhmmss

    系统交互时,用到时间流水号的设计,出现时间流水号相同的情况,故对时间格式化各种情况做了研究 SimpleDateFormat(format) format:年月日  yyyyMMdd时分秒  HHmm ...

  4. Cisco 12系列 AP 初始化配置-2-初始化配置

    用于SSH登陆这个设备 bridge irb bridge 1 route ip  开启路由功能 interface BVI1 ip address 10.15.106.44 255.255.255. ...

  5. BZOJ.2115.[WC2011]Xor(线性基)

    题目链接 \(Description\) 给定一张无向带边权图(存在自环和重边).求一条1->n的路径,使得路径经过边的权值的Xor和最大.可重复经过点/边,且边权和计算多次. \(Soluti ...

  6. docker 导出导入镜像

    1.docker export jenkins > my_jenkins.tar   导出镜像到本地 cat my_jenkins | docker import my_jenkens:0.0. ...

  7. 获取当前泛型类的传入,BaseDaoImpl<T> implements BaseDao<T>

    public abstract class BaseDaoImpl<T> implements BaseDao<T> { private Class<T> claz ...

  8. eclipse 导入android 项目重名解决方法

    在进行andoid 开发时会用到许多的开源框架,但有时候发现几天框架的项目名字都是 library. 解决方法: 1.如果项目中没有 .project 文件,直接修改项目文件夹的名字即可,注意在你引用 ...

  9. 自己遇到过的出现java.lang.StackOverflowError的原因

    public static JSONArray geth24Weather(String result) {//获取当天24小时以及第二天的天气结果对象        JSONObject fromO ...

  10. css3的transform,translate和transition之间的区别与作用

    transform 和 translate transform的中文翻译是变换.变形,是css3的一个属性,和其他width,height属性一样 translate 是transform的属性值,是 ...