10

迁移到 SQL Server 2017 后遇到有趣的问题。

绝对路径测试

backup database master to disk = 'C:\Temp\1\2\3\master.bak'

按预期在 C:\Temp\1\2\3\ 中创建备份。

相对路径测试#1

backup database master to disk = 'C:\Temp\1\2\3\..\master.bak'

在 C:\Temp\ 中创建备份

预期:C:\Temp\1\2\

相对路径测试#2

backup database master to disk = 'C:\Temp\11\22\33\..\master.bak'
backup database master to disk = 'C:\Temp\111\222\333\..\master.bak'
backup database master to disk = 'C:\Temp\bin\bin\bin\..\master.bak'

在文件夹 C:\Temp\11\、C:\Temp\111\、C:\Temp\bin\ 中创建备份

预期:分别为 C:\Temp\11\22\、C:\Temp\111\222\ 和 C:\Temp\bin\bin\。

相对路径测试#3

backup database master to disk = 'C:\Temp\Folder1\Folder2\Folder3\..\master.bak'
backup database master to disk = 'C:\Temp\1111\2222\3333\..\master.bak'

备份按预期分别在文件夹 C:\Temp\Folder1\Folder2 和 C:\Temp\1111\2222 中创建。

如您所见,所有相对路径都具有相同的深度,但根据文件夹名称的长度,备份文件位于不同的级别。我无法使用 SQL Server 2014 复制此问题。我能够在 SQL Server 2017 RTM 和 RTM-CU2 中复制此问题。

操作系统:Windows Server 2016。粘贴到 Windows 资源管理器时,路径会正确解析。

当相对路径包含短(4 个字符以下)文件夹名称时,如何使它们工作?

4

2 回答 2

1

这似乎已在 SQL Server 2017 CU14(或更早版本)中得到修复。

于 2019-04-29T09:45:37.753 回答
0

在“Microsoft SQL Server 2017 (RTM) - 14.0.1000.169 (X64)”上确认

这是一个错误!但是,在玩弄它之后,我找到了一种解决方法,方法是在目录名称后添加另一个点。

backup database master to disk = 'C:\Temp\1.\2.\3.\..\master.bak'

这成功备份到“C:\Temp\1\2\”。我没有找到为什么这有效的参考。此外,如果可能的话,远离低字符目录可能是个好主意。

于 2019-03-19T13:17:48.660 回答