百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

系统库-SQL Server Master探究(显示数据库的sql语句)

liuian 2025-04-05 20:08 9 浏览

概述

最近公司做了一个关于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 语句,则将会在主数据库中创建对象。因为当我们在 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.cnblogs.com/lkj371/p/16731903.html,转载请注明出处,欢迎转发、点赞和关注!

相关推荐

x-cmd install | jellex - 用 Python 语法在终端里玩转 JSON 数据!

还在为命令行下处理JSON数据烦恼吗?jellex来了!它是一款基于终端的交互式JSON和JSONLines数据处理工具,让你用熟悉的Python语法,轻松过滤、转换和探索JSO...

一篇长文带你在Python里玩转Json数据

Json简介Json(JavaScriptObjectNotation)很多网站都会用到Json格式来进行数据的传输和交换,就像上篇我提到的网易云音乐接口,它们返回的数据都是Json格式的。这因为...

Python JSON 魔法手册:数据转换的终极艺术

对话实录小白:(崩溃)我从API拿到了JSON数据,怎么变成Python对象?专家:(掏出魔法书)用json模块,轻松实现数据转换!JSON基础三连击1.字符串Python对...

Python JSON 详解教程(python json())

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式(lightweightdatainterchangeformat)常用于Web应用、配置文件(co...

Python 数据的 JSON 格式序列化及反序列化

在Python中,将数据转换为JSON格式非常简单,可以使用内置的json模块。json模块提供了json.dumps()和json.dump()方法,用于将Python对象...

如何使Python类可JSON序列化(python json 类)

技术背景在Python开发中,JSON(JavaScriptObjectNotation)是一种常用的数据交换格式。然而,Python的json模块默认只能序列化一些基本数据类型,如字典、列表、字...

详细介绍一下Python如何对JSON格式数据进行处理?

在Python中对于JSON数据的处理是在日常开发中的常见需求之一。通常情况下,对JSON数据的处理主要涉及到如下的的几个步骤对于JSON数据的解析操作对于JSON数据的处理操作对于JSON数据的格式...

Python 字典l转换成 JSON(python转化字典)

本文需要5分钟。如果对您有用可以点赞评论关注.Python字典到JSONJSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,它基于ECMAScrip...

打造熟悉的VS界面风格(vs界面设计美化)

用惯了老机子的VS界面,换新机子时,各种不适应。现在重新打造老款样式:1)下载VisualStudio2013ColorThemeEditorhttps://marketplace.vis...

办公小技巧:全部亮相 让Excel单元格完全显示文本

平时我们在使用Excel制作表格的时候,经常会遇到由于文本内容较多,导致这些内容无法在一个单元格中完全显示。常规的方法是将单元格设置为“自动换行”,但是这样会影响整个文件的美观。下例是某小区的入住登记...

WinForms 中的 CheckBox 控件使用指南

在WinForms中,CheckBox控件是一个允许用户选择或取消选择的单选按钮。它通常用于表示布尔值(真/假)或允许多选的情况。以下是如何使用CheckBox控件的一些基本信息和示例代码。创建...

图片转文字--四种OCR工具的安装和使用

本文仅测试简单的安装和使用,下一步应该是测试不同数据集下的检测准确率和检测效率,敬请期待。作者的系统环境是:笔记本:ThindPadP520OS:win11显卡:QuadroP520一、EasyO...

C# 给Word每一页设置不同图片水印

Word中设置水印时,可加载图片设置为水印效果,但通常添加水印效果时,会对所有页面都设置成统一效果,如果需要对每一页或者某个页面设置不同的水印效果,则可以参考本文中的方法。下面,将以C#代码为例,对W...

集成的面向对象控件Xtreme Controls正式发布v17.0.0

CodejockXtremeControls为Windows图形用户软件工程师提供众多的有关MFC的控件产品,该产品是通过完全测试并专门为图形用户设计的一款专业控件。它是一款集成了面向对象的控件被...

Win10 Build 10061老问题修复新问题来

|责编:刘菲菲【中关村在线软件资讯】4月23日消息:微软今天正式推送了Windows10Build10061预览版这个版本除了正常的功能更新和调整外,还修复了多个bug。其中一部分对于开发者开...