系统库-SQL Server Master探究(显示数据库的sql语句)
liuian 2025-04-05 20:08 37 浏览
概述
最近公司做了一个关于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
要在 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,转载请注明出处,欢迎转发、点赞和关注!
相关推荐
- 2025win7专业版激活密钥(2020win7专业版永久激活码)
-
cad序列号和密钥是111-111111,可以通用的,但激活码则需要通过CAD2014注册机对申请号的换算才能得出结果,当然结果有很多,用户可以不断的Generate一个。cad序列号和密钥是111-...
- window7下载itunes什么版本(window7怎么下载itunes)
-
出现此问题一般是因为itunes没有正确安装,可以参考如下解决方法:1.请查看本机电脑数位,计算机---右键---属性---看是32的还是64的;2.官网下载数位对应的iTunes;3...
- u盘什么牌子的好(大容量的u盘什么牌子好)
-
十大耐用云U盘排行分别是:第一名闪迪第二名雷克沙第三名金士顿第四名三星第五名美商海盗船第六名东芝第七名惠普第八名威刚第九名台电第十名朗科。十大耐用云U盘排行分别是:第一名闪迪第二名雷克沙第三名金士顿第...
- 英文翻译器下载(英文翻译器软件下载)
-
APK(全称:Androidapplicationpackage,Android应用程序包)是Android操作系统使用的一种应用程序包文件格式,用于分发和安装移动应用及中间件。一个Android...
- oppo主题包下载(oppoi主题下载)
-
opporeno5壁纸可以选择主题商店下载。1、打开手机设置,点击【个性化定制】,选择壁纸。2、可以选择本地相册、静态壁纸、动态壁纸、ART+,还可以选择主题商店。3、选择自己喜欢的壁纸,点击设置即...
- 硬盘开盘恢复数据(硬盘开盘恢复数据怎样收费)
-
硬盘因为某些原因损坏,比如磁头损坏,用于驱动磁臂移动的电机烧毁等故障,可以通过打开硬盘盘体,更换相应的部件来维修的办法,以便进行数据恢复工作,这也就是一般所说的“开盘”。 开盘维修必须在无尘环境...
- 微软surface平板(微软surface平板电脑的降温散热是由风扇进行的吗)
-
可以。包括微软Surface平板电脑在内的一系列Windows平板,它们搭载的系统都是与电脑完全相同的Windows系统,其界面和操作方式都与电脑无异,并且全面支持电脑EXE应用程序,比如功能完整的O...
- 怎样恢复电脑删除的文件(怎样恢复电脑删除的文件记录)
-
文件误删了之后,先停止对电脑上其他文件的操作,然后判断该文件删除方式,如果是普通删除的文件可以打开回收站进行查看,之后进行还原的操作,如果是永久删除的文件,那可以借助到专业的数据恢复软件来进行恢复操作...
- win7纯净原版(win7旗舰纯净原版)
-
windows7ghost纯净版特色:1、专业为电脑制作,定制版系统使笔记本电脑运行更加可靠。2、安装盘经过多名电脑安装人员测试,稳定性和兼容性非常好。3、通过多台不同硬件型号的计算机测试,没有蓝屏,...
- 电脑摄像头驱动器怎么安装(电脑摄像头的驱动程序)
-
摄像头驱动的安装方法:首先,先取出摄像头,然后将USB端口插入电脑的端口中。当然,如果是需要长时间使用,建议将其插入后面板上。其次,初次使用摄像头时,系统可能会搜索驱动程序进行安装。那些免驱动的都可以...
- win10虚拟机装win7(win10虚拟机怎么装win7)
-
WIN7系统下是可以安装Win10虚拟机,用户可以按照以下方法安装:1、网上搜索下载安装360软件管家;2、在搜索栏里输入VM,然后在VMwareWorkstation旁点下载,系统会自动安装;3、安...
- u盘启动盘怎么还原成普通u盘
-
将U盘还原为普通U盘的方法如下:1.在电脑上打开磁盘管理工具,找到你想要还原的U盘。2.删除该U盘中所有的分区和卷标,在删除时,需要格外小心,确保不要删错其他存储设备。可以右键点击该分区来进行删除...
- 最新款手机vivo(vivo最新款手机及价格表)
-
vivoX60Pro+、vivoX70Pro、vivoX60、vivoX70、vivoX70Pro+、vivoiQOO7、vivoiQOO7Pro、vivoIQOO8、viv...
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
