sql server 数据库文件(系统库?本栏目通过对sql server 数据库文件(系统库问题整理,来做出以下的解答希望对你有所帮助。
通过以下几个事实,我们将阐明master一些重要特性和功能。
1 、 登录帐户和其他实例范围的元数据存储在 SQL Server master库中
SELECT name AS LoginName, password_hash FROM sys.sql_logins WHERE name='sa'
我们可以从 SQL 查询中看到登录名和密码哈希:
这是因为包含系统级信息的表是隐藏的,并且在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 数据库上执行备份操作,我们可以看到唯一可用的选项是完整备份。
END,本文到此结束,如果可以帮助到大家,还望关注本站哦!