当前位置:Gxlcms > mysql > mssql返回表的创建语句

mssql返回表的创建语句

时间:2021-07-01 10:21:17 帮助过:23人阅读

if OBJECT_ID(sp_create_table_sql,P) is not nulldrop proc sp_create_table_sqlgocreate proc sp_create_table_sql ( @tablename varchar(255) ) as begin -- exec sp_create_table_sql Ad_AdGroup -- 0. 弘恩 -- 1. 不支持非主键类的索引 -- 2. 不支持主

  1. if OBJECT_ID('sp_create_table_sql','P') is not null
  2. drop proc sp_create_table_sql
  3. go
  4. create proc sp_create_table_sql ( @tablename varchar(255) )
  5. as
  6. begin
  7. -- exec sp_create_table_sql 'Ad_AdGroup'
  8. -- 0. 弘恩
  9. -- 1. 不支持非主键类的索引
  10. -- 2. 不支持主分键的非默认排序
  11. -- 3. 不支持DEFAULT
  12. -- 4. 不支持计算列
  13. -- 5. 待完整
  14. declare @sql_create varchar(max) = '';
  15. declare @sql_column varchar(max);
  16. declare @sql_primary varchar(max);
  17. with cte as
  18. (
  19. select QUOTENAME( c.name )+' '+
  20. TYPE_NAME(c.system_type_id)+' '+
  21. case when TYPE_NAME( c.system_type_id) in ('char','varchar','decimal') then ' ( ' else '' end +
  22. case when TYPE_NAME( c.system_type_id) in ('char','varchar','nvarchar' ) then cast(max_length as varchar) else '' end+
  23. case when TYPE_NAME( c.system_type_id) in ('decimal' ) then cast(c.precision as varchar)+','+cast(c.scale AS varchar) else '' end+
  24. case when TYPE_NAME( c.system_type_id) in ('char','varchar','decimal') then ' ) ' else '' end +
  25. case when c.is_nullable = 1 then ' null ' else ' not null ' end +
  26. case when c.is_identity = 0 then ' ' else ' identity ' end sqlstr ,
  27. column_id
  28. from sys.objects as o
  29. join sys.columns as c on o.object_id = c.object_id
  30. where o.name = @tablename and o.type = 'U'
  31. )
  32. select @sql_column = stuff(
  33. (select ',' + sqlstr + CHAR(10)
  34. from cte
  35. order by column_id asc
  36. for xml path('') ),1,1,'')
  37. ;
  38. select @sql_primary = stuff((
  39. select ',' + c.name
  40. from sys.index_columns as i
  41. join sys.indexes as ix on i.object_id = ix.object_id and i.index_id = ix.index_id
  42. join sys.columns as c on i.object_id = c.object_id and i.column_id = c.column_id
  43. where OBJECT_NAME(i.object_id) = @tablename
  44. and ix.is_primary_key = 1
  45. order by i.key_ordinal
  46. for xml path('')
  47. ),1,1,'')
  48. set @sql_create = ' create table ' + @tablename + '( '
  49. + @sql_column
  50. + case when len(@sql_primary) >= 1 then (', primary key ( ' + @sql_primary + ')') else '' end
  51. + ' ) '
  52. print ' -- @sql_create -- '
  53. print @sql_create
  54. end

人气教程排行