4

我的 WPF 应用程序正在使用 Microsoft.Win32.OpenFileDialog 来选择要打开的 SQL Server 2008 数据库。

它工作正常,但有一个问题:当对话框中选择的数据库之前在上次启动后的某个时间打开时,该文件似乎在后台由 SQL 服务器保持打开状态(即使它没有被我的应用程序和我的应用程序打开)应用程序已重新启动)。当在 OpenFileDialog 中单击确定时,这会导致“文件被另一个应用程序使用”警告,并且在计算机重新启动之前我无法使用该对话框打开该特定数据库。似乎 OpenFileDialog 试图打开选定的文件并发现它已被另一个应用程序(SQL Server)打开。如何禁用 OpenFileDialog 尝试打开所选文件并仅返回所选文件的文件名而不进行任何检查?

我的代码如下所示:

public void OpenDatabase() {
    // Let user select database to open from file browser dialog
    // Configure open file dialog box
    var dlg = new Microsoft.Win32.OpenFileDialog();
    dlg.FileName = ""; // Default file name
    dlg.DefaultExt = ".mdf"; // Default file extension
    dlg.Filter = "Databases (.mdf)|*.mdf|All Files|*.*"; // Filter files by extension 
    dlg.CheckFileExists = false;
    dlg.CheckPathExists = false;

    // Show open file dialog box
    bool? result = dlg.ShowDialog();    // Gives file in use warning second time!

    // Process open file dialog box results 
    if (result == true) {
        // Open document 
        string filename = dlg.FileName;
        TryOpenDatabase(filename);
    }
}
4

2 回答 2

5

底层选项是 OFN_NOVALIDATE 用于早期 Windows 版本,FOS_NOVALIDATE 用于您在更高版本的 Windows 和 .NET 上获得的 Vista 对话框。来自 MSDN 的描述:

不要检查会阻止应用程序打开所选文件的情况,例如共享冲突或访问被拒绝错误。

这就是您现在看到的情况,对话框看到数据库文件存在共享冲突。这个选项实际上暴露在 OpenFileDialog 包装类上,添加这行代码来解决你的问题:

  dlg.ValidateNames = false;
于 2013-01-01T13:05:37.820 回答
3

MSDN 论坛有一篇关于这个的帖子

它在 OpenFileDialog API 中,您可以使用

ValidateNames = false

Dialog

于 2013-01-01T11:03:05.190 回答