[英]How does EF Code First create connection string first time?
給定的:一個MVC(代碼優先DB)項目,需要第一次重新生成“默認”連接字符串。
原因我有一些錯誤,試圖修復卸載SQL Server並重新安裝所需的錯誤。 現在項目將無法連接任何東西。 Web Config仍顯示舊字符串,如下所示:
<add name="DefaultConnection" connectionString="Data Source=(LocalDb)\v11.0;AttachDbFilename=|DataDirectory|\aspnet-TestReporting-20150127073048.mdf;Initial Catalog=aspnet-TestReporting-20150127073048;Integrated Security=True" providerName="System.Data.SqlClient" />
由於重新加載SQL2012 Express並確保在安裝時檢查了LocalDB,因此沒有建立連接,也沒有從先前運行的項目生成數據庫。
事實證明,在我的情況下,連接字符串失敗了,因為在連接字符串中有一個AttachFile name屬性值,而MDF文件不存在! 雞肉和雞蛋類型問題。
步驟1)要獲取Code First來重新生成MDF文件,只需將DBContext類名重命名為新的名稱。 不是最佳選擇,但祝您好運。
第2步)我還刪除了連接字符串中的AttachFile配置,只是為了了解這是如何工作的,...甚至不需要附加東西!
<add name="DefaultConnection"
connectionString="Data Source=(LocalDb)\v11.0;
Initial Catalog=TestReporting;
Integrated Security=True"
providerName="System.Data.SqlClient" />
最后,MDF生成似乎存在錯誤。 Code First至少應查找該文件,然后再決定要執行的操作,因為任何遷移工作均不起作用,CreateIfNotExists不起作用,重新安裝SQL 2012不起作用,甚至“修復” VS2013也不起作用...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.