SQL Server系统表的应用
创始人
2024-07-17 12:30:45
0

SQL Server系统表是SQL数据库中的重要概念,下面对SQL Server系统表的应用作了详尽的阐述,如果您感兴趣的话,不妨一看。

SQL Server系统表的应用

在应用SQL Server的基于客户机/服务器体系结构的信息系统开发中,有时需要将后台SQL Server上的某一数据库的表结构都打印出来,以便于开发人员查阅及最终文档的形成。SQL Server本身提供了一个系统存储过程(SP_COLUMNS),可以完成对单个表结构的查询,只要在SQL Server的ISQL-W工具中键入SP_COLUMNS “表名”,并执行即可得到结果集。但该方法有许多不足之处,其主要缺点是:

1) 只能对单表进行操作,当需要查询一个数据库中所有的表时,需要多次执行SP_COLUMNS ,因此显得非常繁琐。

2) 查询结果集中包含了许多不必要的信息。

下面我们创建一个存储过程来完成对某一个数据库中所有表结构的查询。

在创建一个数据库的同时,系统会自动建立一些SQL Server系统表,限于篇幅的缘故我们在这里只介绍与应用实例有关的三个系统表(SYSOBJECTS,SYSCOLUMNS,SYSTYPES)及其相关的字段。

表SYSOBJECTS为数据库内创建的每个对象(约束,规则,表,视图,触发器等)创建一条记录。

该表相关字段的含义如下:

SYSOBJECTS.name 对象名,如:表名,视图名。

SYSOBJECTS.id 对象id。

SYSOBJECTS.type 对象类型(p存储过程,v视图,s系统表,u用户表)。

表SYSCOLUMNS 为每个表、视图中的每个列和每个存储过程的每个参数创建一条记录。

该表相关字段的含义如下:(此处的列系指数据库中每个表、视图中的列)

SYSCOLUMNS. id 该列所属的表的id,可与SYSOBJECTS.id相关联

SYSCOLUMNS.colid 列id,表示该列是表或视图的第几列。

SYSCOLUMNS.type 物理存储类型,可与SYSTYPES.type相关联。

SYSCOLUMNS.length 数据的物理长度。

SYSCOLUMNS.name 列名字,即字段名。

SYSCOLUMNS .Pre 列的精度级。

SYSCOLUMNS .Scale 列的标度级。

表SYSTYPES 为每个系统和每个用户提供的数据类型创建一条记录,如果它们存在,给定域和默认值,描述系统提供的数据类型的行不可更改。

该表相关字段的含义如下:

SYSTYPES.name 数据类型的名字。

SYSTYPES.type 物理存储数据类型。

在SQL SERVER的企业管理器(SQL ENTERPRISE MANAGER)中,选定某一数据库,创建存储过程print_dbstructure。

源代码如下:

  1. if exists (select * from sysobjects where id = object_id('dbo. print_dbstructure  
  2.  
  3. ') and sysstat & 0xf = 4) 存储过程  
  4.  
  5. drop procedure dbo. print_dbstructure  
  6.  
  7. GO  
  8.  
  9. CREATE PROCEDURE print_dbstructure  
  10.  
  11. AS  
  12.  
  13. SELECT DISTINCT sysobjects.name, syscolumns.colid,  
  14. syscolumns.name, systypes.name, syscolumns.prec, syscolumns.scale  
  15. FROM syscolumns, sysobjects, systypes  
  16. WHERE sysobjects.id = syscolumns.id AND systypes.type = syscolumns.type AND ((sysobjects.type='u'))  
  17. GO  

首先判断是否存在一个名为print_dbstructure的存储过程,如果存在,就摘除它,否则,定义SQL语句建立新的存储过程。从三个系统表中选出满足条件的记录(即该数据库中保存在系统表中的用户表信息)。

执行时,在ISQL_W工具中,选定print_dbstructure所在的数据库,执行该存储过程,即可得到结果集(即该数据库中用户表的结构信息)。

 

 

【编辑推荐】

Sql Server全文索引的迁移

SQL Server全文索引的用法

SQL Server删除用户失败的解决方法

SQL Server删除表信息的三种方法

SQL Server存储过程的删除方法

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...