3

我已经编写了代码来检查数据库是否存在,如果不存在,那么我正在尝试从我的本地目录附加数据库。我的代码是:

        SqlConnection con = new SqlConnection(@"Data Source=CENSYS08\SQLEXPRESS;Initial Catalog=master;Integrated Security=True");
        con.Open();

        SqlDataAdapter da = new SqlDataAdapter("select name from sys.databases", con);
        DataTable dt = new DataTable();
        da.Fill(dt);

         string[] array = dt
             .AsEnumerable()
             .Select(row => row.Field<string>("Name"))
             .ToArray();

        if(!array.Contains("cstmrDB",StringComparer.OrdinalIgnoreCase))
        {
            SqlCommand cmd = new SqlCommand("sp_attach_db");
            cmd.Connection = con;
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Parameters.AddWithValue("@dbname", "cstmrDB");
            cmd.Parameters.AddWithValue("@filename1", @"C:\Naresh WORK AREA\My Projects\AttachDB\Data\cstmrDB.mdf");
            cmd.ExecuteNonQuery();

        }

还有一件事,我已经授予了我的本地文件的权限this。事件它抛出异常为

无法打开物理文件“C:\Naresh WORK AREA\My Projects\AttachDB\Data\cstmrDB.mdf”。操作系统错误 2:“2(系统找不到指定的文件。)”。

如何将我的数据库附加到 sql server。

4

2 回答 2

2

您应该删除路径中的空格,使用 '_' 之类的 - C:\Naresh_WORK_AREA\My_Projects\AttachDB\Data\cstmrDB.mdf
如果此问题仍未解决,请尝试以下代码。您还可以删除代码中用于检查查询中的数据库名称的额外步骤。

string query = "select name from sys.databases where name='cstmrDB'";
SqlConnection con = new SqlConnection(@"Data Source=CENSYS08\SQLEXPRESS;Initial Catalog=master;Integrated Security=True");

    SqlDataAdapter da = new SqlDataAdapter(query , con);
    DataTable dt = new DataTable();

con.Open();
    da.Fill(dt);

if(dt.Rows.Count==0)
{
   query=" CREATE DATABASE AdventureWorks2008R2 ON"+ 
   " (FILENAME = 'C:\Naresh_WORK_AREA\My_Projects\AttachDB\Data\cstmrDB.mdf'), "+
   " (FILENAME = 'C:\Naresh_WORK_AREA\My_Projects\AttachDB\Data\cstmrDB.ldf'),"+
       " (FILENAME = 'c:\myFTCatalogs\cstmrDBCat')"+
   " FOR ATTACH;"

   SqlCommand cmd = new SqlCommand(query);
       cmd.Connection = con;
       cmd.ExecuteNonQuery();
}
con.Close();
于 2013-09-05T11:33:14.583 回答
0

您还应该有关联的 .ldf(日志文件)文件以及 .mdf,否则会抛出错误

于 2013-09-05T08:05:16.007 回答