您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

获取mssql 表的结构

2024/4/10 23:11:58发布13次查看
获取 制定表的 结构 . ---此脚本只有在sql server 2000下面有效. go create proc gettablestruct @tabname varchar(20) as select 表名 = case when a.colorder=1 then d.name else '' end, 表说明 = case when a.colorder=1 then isnull(f.value,'') else '
获取制定表的结构.
---此脚本只有在sql server 2000下面有效.
go
create proc gettablestruct
@tabname varchar(20)
as
select    
          表名           =   case   when   a.colorder=1   then   d.name   else   ''   end,  
          表说明           =   case   when   a.colorder=1   then   isnull(f.value,'')   else   ''   end,  
          字段序号       =   a.colorder,  
          字段名           =   a.name,  
          标识               =   case   when   columnproperty(  a.id,a.name,'isidentity')=1   then   '√'else   ''   end,  
          主键               =   case   when   exists(select   1   from  sysobjects   where   xtype='pk'   and   parent_obj=a.id   and   name  in   (  
                                            select   name   from   sysindexes   where   indid   in(  
                                                  select   indid  from   sysindexkeys   where   id   =   a.id   and   colid=a.colid)))  then   '√'   else   ''   end,  
          类型               =   b.name,  
          占用字节数   =   a.length,  
          长度               =   columnproperty(a.id,a.name,'precision'),  
          小数位数       =   isnull(columnproperty(a.id,a.name,'scale'),0),  
          允许空           =   case   when   a.isnullable=1   then   '√'else   ''   end,  
          默认值           =   isnull(e.text,''),  
          字段说明       =   isnull(g.[value],'')  
from    
          syscolumns   a  
left   join    
          systypes   b    
on    
          a.xusertype=b.xusertype  
inner   join    
          sysobjects   d    
on    
          a.id=d.id     and   d.xtype='u'   and     d.name'dtproperties'  
left   join    
          syscomments   e    
on    
          a.cdefault=e.id  
left   join    
          sysproperties   g    
on    
          a.id=g.id   and   a.colid=g.smallid      
left   join    
          sysproperties   f    
on    
          d.id=f.id   and   f.smallid=0  
where    
          d.name in (@tabname)        --如果只查询指定表,加上此条件  
order   by    
          a.id,a.colorder
exec gettablestruct spt_values
---此脚本作用是获取制定表的结构.
---版本:sql server2005
use handk
if exists(
select * from sysobjects where name='gettablestruct' and type='p'
)
drop proc gettablestruct
go
create proc gettablestruct
@tabname varchar(20)
as
select    
          表名           =   case   when   a.colorder=1   then   d.name   else   ''   end,  
          表说明           =   case   when   a.colorder=1   then   isnull(f.value,'')   else   ''   end,  
          字段序号       =   a.colorder,  
          字段名           =   a.name,  
          标识               =   case   when   columnproperty(  a.id,a.name,'isidentity')=1   then   '√'else   ''   end,  
          主键               =   case   when   exists(select   1   from  sysobjects   where   xtype='pk'   and   parent_obj=a.id   and   name  in   (  
                                            select   name   from   sysindexes   where   indid   in(  
                                                  select   indid  from   sysindexkeys   where   id   =   a.id   and   colid=a.colid)))  then   '√'   else   ''   end,  
          类型               =   b.name,  
          占用字节数   =   a.length,  
          长度               =   columnproperty(a.id,a.name,'precision'),  
          小数位数       =   isnull(columnproperty(a.id,a.name,'scale'),0),  
          允许空           =   case   when   a.isnullable=1   then   '√'else   ''   end,  
          默认值           =   isnull(e.text,''),  
          字段说明       =   isnull(g.[value],'')  
from    
          syscolumns   a  
left   join    
          systypes   b    
on    
          a.xusertype=b.xusertype  
inner   join    
          sysobjects   d    
on    
          a.id=d.id     and   d.xtype='u'   and     d.name'dtproperties'  
left   join    
          syscomments   e    
on    
          a.cdefault=e.id  
left   join    
      sys.extended_properties    g     ---这里与sql server 2000 有不同之处
on    
a.id=g.major_id   and   a.colid=g.minor_id  
left   join    
        sys.extended_properties    f    
on    
      d.id=f.major_id   and   f.minor_id=0
where    
          d.name in (@tabname)        --如果只查询指定表,加上此条件  
order   by    
          a.id,a.colorder
go
exec gettablestruct item
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product