快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

将SQL SERVER中所有表的列信息显示出来

 正在作一个关于SQL SERVER数据库导入Excel文件的程序,要读取数据库中的列的信息,从网上找了很多资料,终于总结出来比较理想的sql语句,执行后返回的列分别是:表名、列名、列类型、列长度、列描述、是否主键,语句如下:

1 Select Sysobjects.Name As Tb_name, Syscolumns.Name As Col_name, Systypes.Name As Col_type, Syscolumns.Length As Col_len, Isnull(Sysproperties.Value,Syscolumns.Name) As Col_memo,
2 Case When Syscolumns.Name In
3 (Select 主键=A.Name
4 From Syscolumns A
5 Inner Join Sysobjects B On A.Id=B.Id And B.Xtype=\\\'U\\\' And B.Name<>\\\'Dtproperties\\\'
6 Where Exists(Select 1 From Sysobjects Where Xtype=\\\'Pk\\\' And Name In (
7 Select Name From Sysindexes Where Indid In(
8 Select Indid From Sysindexkeys Where Id = A.Id And Colid=A.Colid
9 )))
10 And B.Name=Sysobjects.Name
11 )
12 Then 1 Else 0 End As Is_key
13
14 From Sysobjects,Systypes,Syscolumns
15 Left Join Sysproperties On (Syscolumns.Id = Sysproperties.Id And
16 Syscolumns.Colid = Sysproperties.Smallid)
17
18 Where (Sysobjects.Xtype =\\\'U\\\' Or Sysobjects.Xtype =\\\'V\\\')
19 And Sysobjects.Id = Syscolumns.Id And Systypes.Xtype = Syscolumns.Xtype
20 And Systypes.Name <> \\\'Sysname\\\' And Sysobjects.Name Like \\\'%\\\' Order By Sysobjects.Name, Syscolumns.Colid
返回类别: 教程
上一教程: 一些SELECT检索高级用法
下一教程: 避免使用DSN连接数据库

您可以阅读与"将SQL SERVER中所有表的列信息显示出来"相关的教程:
· 将SQL Server中所有表的列信息显示出来
· 数据库人员手边系列:SQL Server数据表的信息
· MS SQL SERVER中如何得到表的创建语句
· MS SQL SERVER中如何迅速获取表的记录总数
· 关于SQL Server中几个未宣布的访问注册表的扩展存储过
    微笑服务 优质保证 索取样品