系统库-SQL Server Master探究
◆ 概述
最近公司做了一个关于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 代码来获取这些信息:
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 代码。
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又在搞事了!一个依赖轻松搞定权限问题!堪称神器
相关文章
- sql服务器系统时间格式,SQL Server 日期格式和日期操做
- 在Sql Server中调用外部EXE执行程序引发的问题
- T-sql语句修改SQL Server数据库逻辑名、数据库名、物理名的方法
- Sql Server中通过sql命令获取cpu占用及产生锁的sql
- SQL Error (1055) sql_mode=only_full_group_by详解编程语言
- SQL Server群集:让企业系统运行更加稳定(sqlserver群集)
- 比较MySQL和SQL Server的区别(mysql和sqlserver的区别)
- sql server比较Oracle 与 SQL Server的优缺点(oracleltgt)
- MySQL查找提升系统性能的慢SQL(mysql查看慢sql)
- 系统性能如何优化SQL Server系统性能(提高sqlserver)
- serverOracle 与 SQL Server之间的友谊连接(oracle连接sql)
- SQL Server 数据库遭遇“突然闪退”,应急处理指南(sqlserver 闪退)
- SQL Server之重构表:解决数据质量问题(sqlserver重构表)
- 表SQL Server连接:非常实用的列表指引(sqlserver连接列)
- 利用SQL Server资源池节约系统成本(sqlserver资源池)
- SQL Server缓存池:重塑系统性能(sqlserver缓存池)
- SQL Server精简日志:降低系统负担(sqlserver清日志)
- SQL Server的标量值:了解让你更好使用它们(sqlserver标量值)
- SQL Server谜底揭晓:窥探数据库技术的秘密(sqlserver揭秘)
- 使用SQL Server审记记录企业系统运行情况(sqlserver审记)
- SQL Server:根本让人无法忍受(sqlserver太恶心)
- 精通SQL Server外部链接的技巧(sqlserver外链接)
- 处理SQL Server垃圾清理:让系统更稳定运行(sqlserver垃圾)
- 利用SQL Server实现与用友数据的互通(sqlserver和用友)
- SQL Server极速周期管理实战指南(sqlserver周时间)
- 使用SQL Server打造稳定可靠的主机系统(sqlserver主机)
- SQL Server离不开的必要支持!(sqlserver不加n)
- 备份SQL Server系统一周前备份安全稳妥(sqlserver一周前)
- 使用SQL Server存储过程让数据库管理更便捷(sqlserver sp)
- SQL Server 数据库操作指南(操作sqlserver)
- Linux系统下执行SQL脚本文件的技巧(linux执行sql文件)