SQL Server 元数据分类
SQL Server 中维护了一组表用于存储 SQL Server 中所有的对象、数据类型、约束条件、配置选项、可用资源等信息,这些信息称为元数据信息(Metadata),而这些表称为系统基础表(System Base Tables)。在这些基础表中,存在于 master 数据库中的一部分基础表包含系统级范围的信息。存在于特定数据库(也包含 master db)中的基础表包含属于该特定数据库的对象和资源信息。
使用系统管理员身份登录,可以从 sys.objects 中查询所有的系统基础表。
USE master;
SELECT [name] ,type_desc
FROM sys.objects
WHERE type_desc = 'SYSTEM_TABLE'
ORDER BY [name];

系统基础表仅在数据库引擎内部使用,并不是提供的通用功能,所以当变化时可能无法保证兼容性。这些以 "sys" 为前缀的表对象,例如 sysobjects, sysindexes, sysusers, sysdatabases 等,实际上是兼容视图(Compatibility Views)。SQL Server 通过提供兼容视图的集合来保持向后兼容(Backward Compatibility),使得基于这些兼容视图构建的应用程序不会被破坏。而新增的特性,例如表分区、资源调控等将不会被添加到这些视图中。
目前,SQL Server 推荐的访问元数据信息的常规接口是目录视图(Catalog Views)。所有的目录视图,包括动态管理视图 DMV(Dynamic Management Views)和兼容视图(Compatibility Views),均存在于 "sys" Schema 中。

SELECT SCHEMA_NAME(schema_id) AS schema_name
,[name] AS object_name
,type_desc
FROM sys.all_objects
WHERE SCHEMA_NAME(schema_id) = 'sys'
AND type_desc = 'VIEW'
ORDER BY object_name;


名称为 "sys.dm_" 开头的对象即为动态管理视图 DMV(Dynamic Management Views)。这些动态管理对象中既有视图也有函数,但大部分是视图,所以通常称为动态管理视图 DMV(Dynamic Management Views)。DMV 不是基于数据库文件的真实的表,而是基于内部数据库结构的展现。根据 DMV 对象展示的信息的职责范围,它们被分成若干个目录。
- dm_exec_* 包含与用户代码执行和 Session 相关的信息。
- dm_os_* 包含低层系统信息,如 Memory、Locking、Scheduler 等。
- dm_tran_* 包含事务的细节信息。
- dm_io_* 包含网络和磁盘 I/O 活动相关的信息。
- dm_db_* 包含数据库和数据库对象的细节信息,如 Index 等。
目录视图(Catalog Views)是构建在继承模型(Inheritance Model)上的,使得对象的通用属性不必在内部进行重复定义。例如 sys.objects 包含了各种对象类型的通用属性,而 sys.tables 继承自 sys.objects,所以首先包含有与 sys.objects 完全相同的列,然后再添加特定对象类型的附加列。

可以在 SQL Server 2008 R2 System Views Map 位置下载目录视图的映射关系图。

如果要查询某个目录视图的定义,可以使用 object_definition 函数或 sp_helptext 进行查询。
SELECT object_definition (object_id('sys.tables'));
EXEC sp_help 'sys.tables';
EXEC sp_helptext 'sys.tables';

访问 SQL Server 元数据信息还有一些其他方式:
- 信息架构视图(Information Schema Views)
- 系统函数(System Functions)
- 系统存储过程(System Stored Procedures)

例如,通过系统函数查询指定数据库的恢复模型。
SELECT SERVERPROPERTY('Edition') AS Edition
,SERVERPROPERTY('EngineEdition') AS EngineEdition
,DATABASEPROPERTYEX('msdb', 'Recovery') AS RecoveryModel;
目录视图(Catalog Views)是访问 SQL Server 元数据信息的首选接口,其次是系统函数(System Functions)。
《人人都是 DBA》系列文章索引:
| 序号 |
名称 |
|
1 |
|
|
2 |
|
|
3 |
|
|
4 |
|
|
5 |
|
|
6 |
|
|
7 |
|
|
8 |
|
|
9 |
|
|
10 |
|
|
11 |
|
|
12 |
|
|
13 |
|
|
14 |
|
|
15 |
**********转摘:https://www.cnblogs.com/gaochundong/p/everyone_is_a_dba_sqlserver_metadata.html
SQL Server 元数据分类的更多相关文章
- 人人都是 DBA(II)SQL Server 元数据
SQL Server 中维护了一组表用于存储 SQL Server 中所有的对象.数据类型.约束条件.配置选项.可用资源等信息,这些信息称为元数据信息(Metadata),而这些表称为系统基础表(Sy ...
- 探索SQL Server元数据(一)
简介 在数据库中,我们除了存储数据外,还存储了大量的元数据.它们主要的作用就是描述数据库怎么建立.配置.以及各种对象的属性等.本篇简单介绍如何使用和查询元数据,如何更有效的管理SQLServer 数据 ...
- SQL Server元数据查询
原文:SQL Server元数据查询 1.查询触发器的信息 --查询触发器的信息 select name, --触发器名称 (select name from sys.objects where ob ...
- SQL Server元数据损坏(metadata corruption)修复
在升级一个SQL Server 2000的数据库时,遇到了一致性错误,其中有几个错误是元数据损坏(metadata corruption),特意研究了一下这个案例,因为以前也零零散散的遇到过一些一致性 ...
- 探索SQL Server元数据(二)
背景 上一篇中,我介绍了SQL Server 允许访问数据库的元数据,为什么有元数据,如何使用元数据.这一篇中我会介绍如何进一步找到各种有价值的信息.以触发器为例,因为它们往往一起很多问题. 那么如何 ...
- SQL Server 索引分类
什么是索引 拿汉语字典的目录页(索引)打比方:正如汉语字典中的汉字按页存放一样,SQL Server中的数据记录也是按页存放的,每页容量一般为4K .为了加快查找的速度,汉语字(词)典一般都有按拼音. ...
- 探索SQL Server元数据(三):索引元数据
背景 在第一篇中我介绍了如何访问元数据,元数据为什么在数据库里面,以及如何使用元数据.介绍了如何查出各种数据库对象的在数据库里面的名字.第二篇,我选择了触发器的主题,因为它是一个能提供很好例子的数据库 ...
- 如何获取SQL Server数据库元数据的方法
发布时间:2007.06.15 05:05 来源:赛迪网 作者:3946469 元数据简介 元数据 (metadata) 最常见的定义为“有关数据的结构数据”,或者再简单一点就是“关于数据 ...
- 人人都是 DBA(VIII)SQL Server 页存储结构
当在 SQL Server 数据库中创建一张表时,会在多张系统基础表中插入所创建表的信息,用于管理该表.通过目录视图 sys.tables, sys.columns, sys.indexes 可以查看 ...
随机推荐
- IDEA配置Hystrix过程中报错: java.lang.IllegalStateException: No instances available for user-service
最近在练习微服务架构中, 使用IDEA配置完Hystrix, 添加熔断方法后, 在浏览器中访问未启动的( 含有熔断方法注解 )的路径时, 报出了 : 500: No instances availab ...
- 学习Yii(2)
Yii拥有很好的手册,还是中文的,官方的手册很详细.还是应该好好看一下.今天就开始跟着项目代码调试. 上次看到入口脚本,学习一定要快,要用心,抓住时间.不然时间拖久了就忘了.延续不上,大打折扣.而且要 ...
- Java学习笔记-枚举类
实例有限且固定的类成为枚举类 枚举类的实现 早期时候的实现形式: public static final int SEASON_SPRING = 1; public static final int ...
- HDU3191 【输出次短路条数】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3191 How Many Paths Are There Time Limit: 2000/1000 M ...
- 小程序部分机型上一个诡异的偶现bug
如上图所示:开始的时候进到下单页面,价格是0,当选中了商品产生价格的时候,生成的价格如 ¥150,这个时候会只露出¥1以及一小半的5,后面的都被遮挡住了. wxml里是这样的写的 <view w ...
- PTA(Advanced Level)1037.Magic Coupon
The magic shop in Mars is offering some magic coupons. Each coupon has an integer N printed on it, m ...
- 什么是大数据计算服务MaxCompute
大数据计算服务(MaxCompute,原名ODPS)是一种快速.完全托管的EB级数据仓库解决方案. 当今社会数据收集手段不断丰富,行业数据大量积累,数据规模已增长到了传统软件行业无法承载的海量数据(百 ...
- 【AtCoder】AGC003
AGC编号越小越水???? AGC003 A - Wanna go back home 相对方向要么一起有要么一起没有 #include <bits/stdc++.h> #define f ...
- gitlab安装指南(gitlab-ce-9.4.3-ce.0.el7.x86_64 centos7)
1,安装gitlab wget https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/7/gitlab-ce-9.4.3-ce.0.el7. ...
- AlertManager 部署及使用
熟悉了 Grafana 的报警功能,但是 Grafana 的报警功能目前还比较弱,只支持 Graph 的图表的报警.今天来给大家介绍一个功能更加强大的报警工具:AlertManager. 简介 之前我 ...