1

我正在使用 Visual Studio 2012 创建一个 MVC4 Internet 应用程序。我已从 Entity Framework 移出,现在使用本地安装的 SQL Server 2008 R2。

我将连接字符串更改为指向我的本地 SQL Server 实例:

<connectionStrings>
    <add name="DefaultConnection" connectionString="Data Source=.;Initial Catalog=NotesBoard;Integrated Security=SSPI;" providerName="System.Data.SqlClient" />
</connectionStrings>

我的项目中没有其他连接字符串。这工作得很好,但现在我得到了


建立与 SQL Server 的连接时发生与网络相关或特定于实例的错误。服务器未找到或无法访问。验证实例名称是否正确以及 SQL Server 是否配置为允许远程连接。(提供者:SQL 网络接口,错误:26 - 错误定位服务器/指定的实例)

说明:执行当前 Web 请求期间发生未处理的异常。请查看堆栈跟踪以获取有关错误及其源自代码的位置的更多信息。

SQLExpress 数据库文件自动创建错误:
连接字符串指定了本地 Sql Server Express 实例...


奇怪的是,它间歇性地起作用,然后又回到它的损坏状态。

更新:回答Pawel的问题: 我的所有控制器都引用了以下类:

public class DataAccess
{

    public void ExecuteNonQuery(String StoredProc, List<SqlParameter> Parameters)
    {
        String ConnectionString = System.Configuration.ConfigurationManager.ConnectionStrings["DefaultConnection"].ToString();
        SqlConnection cn = new SqlConnection(ConnectionString);

        SqlCommand cm = new SqlCommand(StoredProc, cn);
        cm.CommandType = CommandType.StoredProcedure;

        FillCommandParameters(Parameters, cm);

        cn.Open();
        cm.ExecuteNonQuery();
        cn.Close();
    }

    public DataSet Execute(String StoredProc, List<SqlParameter> Parameters = null)
    {
        String ConnectionString = System.Configuration.ConfigurationManager.ConnectionStrings["DefaultConnection"].ToString();
        SqlConnection cn = new SqlConnection(ConnectionString);

        SqlCommand cm = new SqlCommand(StoredProc, cn);
        cm.CommandType = CommandType.StoredProcedure;

        FillCommandParameters(Parameters, cm);

        SqlDataAdapter da = new SqlDataAdapter();
        da.SelectCommand = cm;
        DataSet ds = new DataSet();

        cn.Open();
        da.Fill(ds);
        cn.Close();

        return ds;
    }

    private static void FillCommandParameters(List<SqlParameter> Parameters, SqlCommand cm)
    {
        if (Parameters != null)
        {
            if (Parameters.Count > 0)
            {
                foreach (var Parameter in Parameters)
                {
                    cm.Parameters.Add(Parameter);
                }
            }
        }
    }
}
4

2 回答 2

0

如果这是 SQL Server Express(标签建议如此),那么您很可能调用了一个命名实例,SQLEXPRESS因为这是 SQL Server Express 安装的默认实例名称。如果是这种情况,您需要将连接字符串更改为Data Source=.\SQLEXPRESS.

于 2013-01-16T18:57:06.340 回答
0

重新部署时,我在 MVC4 站点上遇到了同样的错误。我不能说问题的根本原因是什么,但似乎是在重新部署站点时保留了浏览器中缓存的某些内容(可能是会话 Guid),并且由于某种原因这会导致服务器端代码抛出这个奇怪的错误。

关闭并重新打开浏览器似乎会清除缓存,然后网站按预期工作。这或许可以解释问题的间歇性。

于 2014-03-10T12:26:45.460 回答