EntityFramework 6.0< Code First > 连接 Mysql数据库
2014-02-22 00:27
288 查看
网上有很多关于用EntityFrame来连接Mysql数据库的教程,可是很多并不靠谱,转载的太多了。找了很久,总算是配置好了,现在分享一下。
一,安装:
1、开发环境: VS2013与EF6
2、Mysql数据库为:Mysql Server 6.0
3、安装:Mysql for Visual Studio 1.1.1
下载位置:https://cdn.mysql.com/Downloads/MySQLInstaller/mysql-visualstudio-plugin-1.1.1.msi
4、安装 Mysql Connector/Net 6.8.3 GA
下载位置:http://dev.mysql.com/downloads/connector/net/
二,引用dll:
1、采用Nuget安装EF6.0.2;
2、采用Nuget安装MySql.Data.Entity.EF6
注意:要采用Nuget进行安装,否则可能会缺少相应的dll或者是配置信息
三、配置 web.config或app.config
1、将entitframework节点替代为:
<entityFramework codeConfigurationType="MySql.Data.Entity.MySqlEFConfiguration, MySql.Data.Entity.EF6">
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework"/>
<providers>
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6" />
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
2、添加 ConnectionString节点:
<connectionStrings>
<add name="MyContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=数据库名称;user id=Mysql的登录用户名;password=Mysql server密码;"
providerName="MySql.Data.MySqlClient"/>
</connectionStrings>
四、测试C#代码
六、采用Database First:
这种实现方式与在Sql server下的Database的做法是相同的,但是有时会连接不上Mysql。我一开始就尝试采用Database来连接Mysql,但是在VS2013里一直无法连接到Mysql server。所以我才采用了上面的Code First。但是当我用Code Frist成功之后,我发现,我的VS2013也能够连接到Mysql server了。真是神奇,具体原因我还不清楚。
参考:http://www.nzmk.com/Blogs/BlogsView/tabid/83/EntryId/8/MVC5-EF6-ContosoUniversity-code-first-approach-using-MySQL.aspx
一,安装:
1、开发环境: VS2013与EF6
2、Mysql数据库为:Mysql Server 6.0
3、安装:Mysql for Visual Studio 1.1.1
下载位置:https://cdn.mysql.com/Downloads/MySQLInstaller/mysql-visualstudio-plugin-1.1.1.msi
4、安装 Mysql Connector/Net 6.8.3 GA
下载位置:http://dev.mysql.com/downloads/connector/net/
二,引用dll:
1、采用Nuget安装EF6.0.2;
2、采用Nuget安装MySql.Data.Entity.EF6
注意:要采用Nuget进行安装,否则可能会缺少相应的dll或者是配置信息
三、配置 web.config或app.config
1、将entitframework节点替代为:
<entityFramework codeConfigurationType="MySql.Data.Entity.MySqlEFConfiguration, MySql.Data.Entity.EF6">
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework"/>
<providers>
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6" />
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
2、添加 ConnectionString节点:
<connectionStrings>
<add name="MyContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=数据库名称;user id=Mysql的登录用户名;password=Mysql server密码;"
providerName="MySql.Data.MySqlClient"/>
</connectionStrings>
四、测试C#代码
using System.Data.Entity; namespace StudyEF { public class MyContext : DbContext { public MyContext() : base("name=MyContext") { } public DbSet<Data> Datas { get; set; } } public class Data { public int Id { get; set; } public string Name { get; set; } } class Program { static void Main(string[] args) { Database.SetInitializer(new DropCreateDatabaseAlways<MyContext>()); var context = new MyContext(); context.Datas.Add(new Data{Name="EF6-MySql"}); context.SaveChanges(); } } }五、在Mysql的cmd下查询:
六、采用Database First:
这种实现方式与在Sql server下的Database的做法是相同的,但是有时会连接不上Mysql。我一开始就尝试采用Database来连接Mysql,但是在VS2013里一直无法连接到Mysql server。所以我才采用了上面的Code First。但是当我用Code Frist成功之后,我发现,我的VS2013也能够连接到Mysql server了。真是神奇,具体原因我还不清楚。
参考:http://www.nzmk.com/Blogs/BlogsView/tabid/83/EntryId/8/MVC5-EF6-ContosoUniversity-code-first-approach-using-MySQL.aspx
相关文章推荐
- EntityFramework 6.0< Code First > 连接 Mysql数据库
- EntityFramework 6.0< Code First > 连接 Mysql数据库
- EntityFramework 6.0< Code First > 连接 Mysql数据库
- EntityFramework 6.0< Code First > 连接 Mysql数据库(转)
- 转载:EntityFramework 6.0< Code First > 连接 Mysql数据库
- EntityFramework 6.0< Code First > 连接 Mysql数据库
- Flex连接wcf返回List<object>数据
- <Head First Java>学习笔记--第四章:方法操作实例变量 对象的行为
- Codeforces Round #192 (Div. 2) <全>
- NuGet EF4 Code-First Migration Command (PM>)
- <clean code>-chapter 02 : Meaningful Names
- <Android+Java>(三)连接真机进行调试
- <The Art of Readable Code> 笔记二 (上)
- 苹果iPhone连接wifi就进去www.apple.com主页 下边显示 <HTML><HEAD><TITLE>Success</TITLE></HEAD><BODY>Success</BODY>
- <iphone>连接iphone无法获得照片
- 基连接 <base href="">
- Microsoft.ApplicationServer.Caching.DataCacheException 之 ErrorCode<ERRCA0017>:SubStatus<ES0006>
- The Controls collection cannot be modified because the control contains code blocks (i.e. <% ... %>)
- 当有多个设备online时,命令行窗口通过adb连接指定设备方法----adb -s <serial number> cmd