码迷,mamicode.com
首页 > 数据库 > 详细

[.Net MVC] 使用SQL Server数据库代替LocalDb

时间:2017-02-16 12:54:07      阅读:211      评论:0      收藏:0      [点我收藏+]

标签:带来   tip   value   dbf   filename   失败   mvc   开发   连接字符串   

之前开发的时候一直用的VS2013,所以数据库也用的LocalDb,这给开发带来很大便利。不过由于开发后还要进行部署,就改用了SQL Server 2012,这里总结下过程。

基本环境:VS2013,EF Code First,SQL Server 2012,Win7.

修改领域层的App.config,就是原来用EF Code First生成数据库的那个项目,用LocalDb的时候,EF节点和连接字符串节点:

技术分享
<entityFramework>
  <defaultConnectionFactory type = "System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
    <parameters>
      <parameter value = "v11.0" />
    </parameters>
  </defaultConnectionFactory>
  <providers>
    <provider invariantName = "System.Data.SqlClient" type = "System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
  </providers>
</entityFramework>
技术分享
<add name = "SiaEMS" connectionString = "Data Source=(LocalDb)\v11.0;AttachDbFilename = |DataDirectory|\SiaEMS.mdf;Initial Catalog = SiaEMS;Integrated Security = True" providerName = "System.Data.SqlClient"/>

用SQL Server的话,需要修改这两个节点:

技术分享
<entityFramework>
  <defaultConnectionFactory type = "System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
  <providers>
    <provider invariantName = "System.Data.SqlClient" type = "System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
  </providers>
</entityFramework>
技术分享
技术分享
<add name="SiaEMS"
      connectionString="Data Source = .;
      Initial Catalog = SiaEMS;
      user = sa;
      password = ******;
      MultipleActiveResultSets = True;
      App = EntityFramework"
providerName="System.Data.SqlClient"/>
技术分享

连接字符串里的内容需要注意,Data Source填数据库的服务器端地址,如果是本机就用.代替;Initial Catalog是要连接的数据库的名字;这里使用SQL Server身份验证,填写user和password;这里没有设置Integrated Security,如果设置为True,将采用Windows身份验证模式,前面填写的u和p不起作用;MultipleActiveResultSets作用是指定多活动的结果集是否与指定的链接相互关联,true代表与指定的链接关联,利用这种对链接的关联方式可以减轻系统的负担。

再修改启动项目的Web.config下的连接字符串,修改和上面的一样即可。


到此,完成需要修改的配置。接下来需要生成数据库,在VS2013中打开工具->NuGet程序包管理器->程序包管理器控制台,默认项目选择领域层的项目,依次使用Enable-Migrations,Add-Migration,Update-Database命令生成数据库文件。

安装SQL Server的时候,由于选择了Windows身份验证登录数据库,所以需要在Microsoft SQL Server Management Studio里修改一下。打开管理器,用Windows身份登陆后,服务器上右键属性->安全性,服务器身份验证里选择SQL Server和Windows身份验证模式,确定退出。点开服务器下的安全性->登录名,右键sa属性,常规中输入密码后确定。本来到这里以为就完成了,可是还需要重启服务,才可以使配置生效,由于没走这一步,部署后浏览网站,一直显示数据库登录失败。右键服务器->重新启动,弹出对话框,点是就可以了。

[.Net MVC] 使用SQL Server数据库代替LocalDb

标签:带来   tip   value   dbf   filename   失败   mvc   开发   连接字符串   

原文地址:http://www.cnblogs.com/nxxshxf/p/6404649.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!