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 可以查看 ...
随机推荐
- [转帖]SSH远程登录配置文件sshd_config详解
SSH远程登录配置文件sshd_config详解 2016年06月02日 17:42:25 Field_Yang 阅读数 61386 版权声明:本文为博主原创文章,遵循CC 4.0 by-sa版权 ...
- ValueError: row index was 65536, not allowed by .xls format
报错:ValueError: row index was 65536, not allowed by .xls format 读取.xls文件正常,在写.xls文件,pd.to_excel()时候会报 ...
- http无状态和鉴权解决四种方案
http协议本身是无状态的,但是在实际的web开发中常有一些操作需要有状态.比如想要访问一些私人访问权限的文章,或者这种操作需要明确当前用户身份. 显然,最简单的方案就是每次都发送账户和密码,但是这样 ...
- Java Mysql--链接数据库,数据库字段比较
连接库操作: package com.qa.xxx; import org.springframework.stereotype.Component; import java.lang.reflect ...
- (九)springMvc 的 post 提交乱码
#post 提交乱码 在 web.xml 配置下 过滤器 : <!--解决 post 乱码问题,--> <filter> <filter-name>characte ...
- 数据结构:BF算法
贴上源代码: #include<iostream> using namespace std; int BF(char S[],char T[]) { int i,j; i = j = 0; ...
- NOIP(CSP)答题技巧&小细节
1.主函数类型 通常使用int main(),然而可以使用完全等价的signed main() 解锁 #define int long long 的操作 2.long long 的使用 数列长度/边 ...
- finally代码块的执行
try{ //todo }catch(Exception e){ //todo }finally{ //todo } 1.不管try,catch里面的代码快有无return,finally都会执行 2 ...
- C#学习基础资料记录---字典(Dictionary),时间表示方法(DateTime.Now),文件操作
1.字典 https://www.cnblogs.com/gengaixue/p/4002244.html 2.时间的表示方法 DateTime.Now的多种用法 https://www.cnblog ...
- VBA学习资料分享-4
工作中经常要从数据库把数据跑出来放到EXCEL上,才能进行下一步的操作,那么VBA如何结合SQL提取数据呢?答案就是ADO. 声明和实例变量 引用法——引用Microsoft ActiveX Data ...