系统库-SQL Server Master探究

2022-10-08 14:11:04 浏览数 (1)

◆ 概述

最近公司做了一个关于SQLSERVER的大项目,所以对SQL SERVER进行了探究。master数据库,是SQL Server中最重要的系统数据库。master数据库包含有关 SQL Server 系统的所有信息,包括有关初始化的信息、配置设置、与实例相关的元数据、有关所有其他数据库的信息,例如数据库文件的位置等。这就是为什么主数据库的存在和正常功能对于任何 SQL Server 实例都是至关重要的。在本文中,我们将说明有关这个重要数据库的五个事实。

◆ 解决方案

通过以下几个事实,我们将阐明master一些重要特性和功能。

1 、 登录帐户和其他实例范围的元数据存储在 SQL Server master库中

你有没有想过登录名存储在哪里?例如,您知道“sa”登录名及其密码存储在哪里吗?好吧,登录信息存储在主数据库中。虽然在 SQL 登录的情况下,它们的密码哈希也存储在主数据库中,但对于 Windows 登录,SQL Server 依赖于 Windows 进行身份验证。因此,可以在 master 数据库中找到“sa”帐户及其散列密码。我们可以通过运行下面的 T-SQL 代码来获取这些信息:

代码语言:javascript复制
SELECT name AS LoginName, password_hash 
FROM sys.sql_logins 
WHERE name='sa'

我们可以从 SQL 查询中看到登录名和密码哈希:

不仅登录帐户,而且所有系统级信息都存储在主数据库中。链接服务器和端点是另外两个这样的例子。可能会出现一个问题:我们在哪里可以看到存储所有这些信息的这些表?当我们在SQL Server Management Studio (SSMS)中展开master 数据库的“表”时,我们看不到相关的表。主“表”下没有表 (如果我们没有手动创建),“系统表”下只有四个表,如下所示:

这是因为包含系统级信息的表是隐藏的,并且在SSMS中不可见。

◆ 2、master库并不存储系统对象

有一个常见的误解,即系统对象是存储在主数据库中的。虽然在 SQL Server 的旧版本(例如 SQL Server 2000)中,主数据库包含系统对象,但在新版本中,这些数据不再存储在master数据库中。从 SQL Server 2005 开始,这些对象存储在资源数据库中,这是一个隐藏的只读系统数据库。因此,主数据库不再包含系统对象,例如 sys.objects 中的数据。

◆ 3、如果master数据库不可用,则无法启动 SQL Server

我们知道初始化信息,实例中其他数据库的信息及其文件位置都存储在master库中,如果master库不可用,则实例无法启动。我们可以通过使master库不可用来说明这种行为。为此,我们可以停止实例(强烈建议仅在测试实例上执行所有这些测试),将master库文件(数据和日志或仅其中一个)移动到另一个位置,然后尝试启动实例.

要停止实例,我们打开 SQL Server 配置管理器并选择相应的实例,右键单击它并选择停止。

在使用上面显示的属性选项的实例的启动参数中,我们可以找到master库文件的位置。

所以,让我们将master数据库的数据文件复制到另一个位置。

然后,我们尝试启动实例,方法是右键单击它并选择 Start。

实例将无法启动,我们收到以下错误。

如果我们打开ERRORLOG文件,我们可以看到错误原因描述:

◆ 4、可以在 master 数据库中创建用户对象,但不建议这样做

虽然我们可以在 master 数据库中创建表、存储过程等用户对象,但不建议这样做。但是在某些情况下,有些人出于某些目的不遵循最佳实践并在主数据库中创建用户对象。这通常会发生在T-SQL 代码中没有使用“USE <database>” 语句,则将会在主数据库中创建对象。因为当我们在 SSMS 中打开一个新的查询窗口时,默认数据库是主数据库(除非它被更改)。

要在 master 数据库中查找用户创建的对象,我们可以运行以下 Transact-SQL 代码。

代码语言:javascript复制
SELECT *FROM master.sys.objects 
WHERE is_ms_shipped=0

其中 is_ms_shipped为 0 或 1(位数据类型字段),并显示对象是由内部 SQL 组件 (1) 还是不是 (0) 创建。在如下的例子中,我们可以看到我们有两个用户创建的对象。

◆ 5、master数据库只允许创建完整备份

建议对master数据库进行全新备份。特别是在我们创建、删除或修改新数据库、登录帐户和更改配置值时,执行主数据库的备份非常重要。另外,如果你已经在master数据库中创建了用户对象(上面不推荐这样做),根据这些用户创建对象的变化,备份master数据库是合理的。无法对主数据库进行事务日志或差异备份。

如果我们尝试在 master 数据库上执行备份操作,我们可以看到唯一可用的选项是完整备份。

◆ 小结

总而言之,我们探讨了有关 SQL Server master数据库的五个有趣事实。具体来说,我们了解到主数据库包含 SQL 身份验证用户的登录帐户和密码哈希。此外,我们了解到master数据库不包含系统对象(自 SQL Server 2005 起,它们存储在资源数据库中)。如果master数据库不可用, SQL Server 实实例则无法启动。此外展示了我们是否可以在主数据库中创建用户对象。最后,我们了解到主数据库的唯一可能备份是完整备份。

来源:

https://www.toutiao.com/article/7148013807389508131/?log_from=df29fc587d143_1664414026761

“IT大咖说”欢迎广大技术人员投稿,投稿邮箱:aliang@itdks.com

来都来了,走啥走,留个言呗~

 IT大咖说  |  关于版权

由“IT大咖说(ID:itdakashuo)”原创的文章,转载时请注明作者、出处及微信公众号。投稿、约稿、转载请加微信:ITDKS10(备注:投稿),茉莉小姐姐会及时与您联系!

感谢您对IT大咖说的热心支持!

  • 相关推荐 推荐文章
  • MySql的InnoDB的三层B 树可以存储两千万左右条数据的计算逻辑
  • 呼吁停用 C/C ,微软 Azure CTO 更青睐 Rust
  • 六边形架构:三个原则和一个实现示例
  • Java 19 正式发布,七大特性齐发,最常用的还是 Java 11
  • Redis 内存淘汰策略,从根儿上理解
  • 这个牛逼了,基于(SpringBoot VUE)实现的自定义拖拽式智能大屏
  • 终于有人把怎么搭建数据指标体系给讲明白了,数据分析师必备
  • SpringBoot企业级技术中台微服务架构与服务能力开发平台
  • SQLSERVER backup 命令总结
  • MyBatisPlus又在搞事了!一个依赖轻松搞定权限问题!堪称神器

0 人点赞