SQL Server系统表sysobjects介绍与使用
来源:互联网 发布:淘宝客优惠券口令推广 编辑:程序博客网 时间:2024/06/14 16:53
关于SQL Server数据库的一切信息都保存在它的系统表格里。我怀疑你是否花过比较多的时间来检查系统表格,因为你总是忙于用户表格。但是,你可能需要偶尔做一点不同寻常的事,例如数据库所有的触发器。你可以一个一个地检查表格,但是如果你有500个表格的话,这可能会消耗相当大的人工。
这就让sysobjects表格有了用武之地。虽然我不建议你更新这个表格,但是你当然有权对其进行审查。
sysobjects 表结构:
列名
数据类型
描述
name
sysname
对象名,常用列
id
int
对象标识号
xtype
char(2)
对象类型。常用列。xtype可以是下列对象类型中的一种:
C = CHECK 约束 D =默认值或 DEFAULT约束 F = FOREIGN KEY约束 L = 日志 FN =标量函数
IF = 内嵌表函数 P =存储过程 PK = PRIMARY KEY约束(类型是 K) RF =复制筛选存储过程
S = 系统表 TF =表函数 TR =触发器 U =用户表 UQ = UNIQUE约束(类型是 K)
V = 视图 X =扩展存储过程
uid
smallint
所有者用户对象编号
info
smallint
保留。仅限内部使用
status
int
保留。仅限内部使用
base_schema_ ver
int
保留。仅限内部使用
replinfo
int
保留。供复制使用
parent_obj
int
父对象的对象标识号(例如,对于触发器或约束,该标识号为表 ID)。
crdate
datetime
对象的创建日期。
ftcatid
smallint
为全文索引注册的所有用户表的全文目录标识符,对于没有注册的所有用户表则为 0
schema_ver
int
版本号,该版本号在每次表的架构更改时都增加。
stats_schema_ ver
int
保留。仅限内部使用。
type
char(2)
对象类型。可以是下列值之一:
C = CHECK 约束 D =默认值或 DEFAULT约束 F = FOREIGN KEY约束
FN = 标量函数 IF =内嵌表函数 K = PRIMARY KEY或 UNIQUE约束
L = 日志 P =存储过程 R =规则 RF = 复制筛选存储过程
S = 系统表 TF =表函数 TR =触发器 U = 用户表 V =视图 X =扩展存储过程
userstat
smallint
保留。
sysstat
smallint
内部状态信息
indexdel
smallint
保留
refdate
datetime
留用
version
int
保留
deltrig
int
保留
instrig
int
保留
updtrig
int
保留
seltrig
int
保留
category
int
用于发布、约束和标识
cache
smallint
保留
你可以用下面的命令列出感兴趣的所有对象:
SELECT * FROM sysobjects WHERE xtype= <type ofinterest>
--例如:查看视图
SELECT * FROM sysobjects WHERE xtype= 'V'
判断数据库中是否已经存在某个表,有的话就删除该表
--方法一:
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[表名]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[表名]
--方法二:
if exists (select * from sysobjects where id = object_id(N'表名') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[表名]
--方法三:
if(Exists(Select * From SysObjects Where xtype='U' And Name='表名'))
drop table [dbo].[表名]
以后继续补充。
某些朋友的一些疑问:
1、问:object_id(N'表名')中N'代表什么意思?
答:N'' 代表 Unicode类型.可以支持不同语种的对象名
3、问:USE master SELECT * FROM ...SysObjects ”...sysobjects ” -- 三个句点的前缀是什么意思?
答:对数据库对象名的 Transact-SQL 引用可以是由四部分组成的名称,格式如下:[server_name.[[database_name].[owner_name]. | database_name.[owner_name]. |owner_name.] ] object_name
- SQL Server系统表sysobjects介绍与使用
- SQL Server系统表sysobjects介绍与使用
- SQL Server系统表sysobjects介绍与使用
- SQL Server系统表sysobjects介绍与使用
- SQL Server系统表sysobjects介绍与使用
- 【转自《一棵树-博客园》】SQL Server系统表sysobjects介绍与使用
- SQL Server系统表sysobjects
- 理解SQL Server系统表sysobjects
- 理解SQL Server系统表sysobjects(摘)
- 理解SQL Server系统表sysobjects
- SQL Server sysobjects 系统表说明
- SQL Server 常用系统表(一) sysobjects
- 关于SQL Server中的系统表——sysobjects
- sql server 系统表sysobjects、sysindexes、syscolumns损坏修复方法
- 【数据库】sql server中的sys.sysobjects系统表
- SQL Server sysobjects 表结构
- SQL Server sysobjects 表结构
- SQL系统表sysobjects和syscolumns字段属性介绍
- MQTT QoS
- WINFORM 设置PICTUREBOX背景透明
- Android唤醒、解锁屏幕代码实例
- oracle数据库基础
- linux查找日志技巧
- SQL Server系统表sysobjects介绍与使用
- offset的bug
- C++的STL中集合(set)的使用说明
- 在启动HDFS时,针对集群中namenode无法识别datanode的问题的解决方法
- 08 CSS-隐藏盒子的5种方法
- 按照从小到大的顺序输出字符串
- JBOSS启动报错Given parent is not an ancestor of this virt
- 一起做RGB-D SLAM(1)
- 顺序表