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

人人都是 DBA(I)SQL Server 体系结构

2

人人都是 DBA(II)SQL Server 元数据

3

人人都是 DBA(III)SQL Server 调度器

4

人人都是 DBA(IV)SQL Server 内存管理

5

人人都是 DBA(V)SQL Server 数据库文件

6

人人都是 DBA(VI)SQL Server 事务日志

7

人人都是 DBA(VII)B 树和 B+ 树

8

人人都是 DBA(VIII)SQL Server 页存储结构

9

人人都是 DBA(IX)服务器信息收集脚本汇编

10

人人都是 DBA(X)资源信息收集脚本汇编

11

人人都是 DBA(XI)I/O 信息收集脚本汇编

12

人人都是 DBA(XII)查询信息收集脚本汇编

13

人人都是 DBA(XIII)索引信息收集脚本汇编

14

人人都是 DBA(XIV)存储过程信息收集脚本汇编

15

人人都是 DBA(XV)锁信息收集脚本汇编

 

**********转摘:https://www.cnblogs.com/gaochundong/p/everyone_is_a_dba_sqlserver_metadata.html

SQL Server 元数据分类的更多相关文章

  1. 人人都是 DBA(II)SQL Server 元数据

    SQL Server 中维护了一组表用于存储 SQL Server 中所有的对象.数据类型.约束条件.配置选项.可用资源等信息,这些信息称为元数据信息(Metadata),而这些表称为系统基础表(Sy ...

  2. 探索SQL Server元数据(一)

    简介 在数据库中,我们除了存储数据外,还存储了大量的元数据.它们主要的作用就是描述数据库怎么建立.配置.以及各种对象的属性等.本篇简单介绍如何使用和查询元数据,如何更有效的管理SQLServer 数据 ...

  3. SQL Server元数据查询

    原文:SQL Server元数据查询 1.查询触发器的信息 --查询触发器的信息 select name, --触发器名称 (select name from sys.objects where ob ...

  4. SQL Server元数据损坏(metadata corruption)修复

    在升级一个SQL Server 2000的数据库时,遇到了一致性错误,其中有几个错误是元数据损坏(metadata corruption),特意研究了一下这个案例,因为以前也零零散散的遇到过一些一致性 ...

  5. 探索SQL Server元数据(二)

    背景 上一篇中,我介绍了SQL Server 允许访问数据库的元数据,为什么有元数据,如何使用元数据.这一篇中我会介绍如何进一步找到各种有价值的信息.以触发器为例,因为它们往往一起很多问题. 那么如何 ...

  6. SQL Server 索引分类

    什么是索引 拿汉语字典的目录页(索引)打比方:正如汉语字典中的汉字按页存放一样,SQL Server中的数据记录也是按页存放的,每页容量一般为4K .为了加快查找的速度,汉语字(词)典一般都有按拼音. ...

  7. 探索SQL Server元数据(三):索引元数据

    背景 在第一篇中我介绍了如何访问元数据,元数据为什么在数据库里面,以及如何使用元数据.介绍了如何查出各种数据库对象的在数据库里面的名字.第二篇,我选择了触发器的主题,因为它是一个能提供很好例子的数据库 ...

  8. 如何获取SQL Server数据库元数据的方法

    发布时间:2007.06.15 05:05    来源:赛迪网    作者:3946469 元数据简介 元数据 (metadata) 最常见的定义为“有关数据的结构数据”,或者再简单一点就是“关于数据 ...

  9. 人人都是 DBA(VIII)SQL Server 页存储结构

    当在 SQL Server 数据库中创建一张表时,会在多张系统基础表中插入所创建表的信息,用于管理该表.通过目录视图 sys.tables, sys.columns, sys.indexes 可以查看 ...

随机推荐

  1. Spring 控制器重定向

    1.示例 return "redirect:/allUser"; redirect是跳转的意思后面是跳转的页面

  2. 【AtCoder】ARC068

    ARC 068 C - X: Yet Another Die Game 显然最多的就是一次6一次5 最后剩下的可能需要多用一次6或者6和5都用上 #include <bits/stdc++.h& ...

  3. Python中的幽灵—编码方式

    首先要搞懂本地操作系统编码与系统编码的区别: 本地操作系统编码方式与操作系统有关,Linux默认编码方式为utf-8,Windows默认编码方式为gbk: 系统编码方式与编译器or解释器有关,Pyth ...

  4. 【第一季】CH04_FPGA设计Verilog基础(一)Enter a post title

    [第一季]CH04_FPGA设计Verilog基础(一) 4.1 Verilog HDL 代码规范 u 项目构架设计 项目的构架用于团队的沟通,以及项目设计的全局把控 u 接口时序设计规范 模块和模块 ...

  5. 【AC自动机】洛谷三道模板题

    [题目链接] https://www.luogu.org/problem/P3808 [题意] 给定n个模式串和1个文本串,求有多少个模式串在文本串里出现过. [题解] 不再介绍基础知识了,就是裸的模 ...

  6. Jobs(一)前端页面

    Java Web工程中的Intellij中Java Web工程的基本目录: 启动web工程后,显示的默认页面是index.html.需要注意的是,本来IDE自建的是index.jsp,我暂时改成了in ...

  7. docker 入门3 - 服务 【翻译】

    入门,第 3 部分:服务 先决条件 安装 Docker 版本 1.13 或更高版本. 获取 Docker Compose.在适用于 Mac 和 Docker 桌面的 Windows 上,它已预安装,因 ...

  8. 微信小程序中weui使用方法

    1.git下载,找到dist文件: https://github.com/wechat-miniprogram/weui-miniprogram 2.把dist文件中的style复制到根目录 app. ...

  9. div 清除浮动的四种方法

    概述:为了解决父级元素因为子级内部高度为0的问题 (很多情况 不方便给父级元素高,因为不知道有多少内容,让里面的盒子自动撑起高度),清除浮动本质叫闭合浮动更好一些,清除浮动就是把浮动的盒子关到里面,让 ...

  10. django 权限控制精简版

    视图代码: 视图代码 def index(request): return render(request,'index.html') def login(request): if request.me ...