IT業界のすみっこ暮らし

ふと気がついたときの記録

EntityFrameworkでMySQL接続


qursaan-howto.blogspot.jp

1、必須条件

「mysql-installer-community-5.7.3.0-m13.msi」をインストールするか 「mysql-visualstudio-plugin-1.1.1.msi」と「mysql-connector-net-6.8.3.msi」をインストールする。

ダウンロードミラー http://mirror.cogentco.com/pub/mysql/MySQLInstaller/

2、Entity Framework

「App.config」や「Web.config」にあるentityFrameworkのデフォルトタグを削除する。

<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>

下記のentityFrameworkタグを追加する。

<entityFramework>  
<defaultConnectionFactory type="MySql.Data.Entity.MySqlConnectionFactory, MySql.Data.Entity.EF6" /> 
<providers>  
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6" />     
</providers>  
</entityFramework>

3、References(参照)追加

MySql.Data.dll
MySql.Data.Entity.EF6.dll
MySql.Web.dll

4、プロジェクトをリビルド

5、ADO.NET Entity Data Modelの追加手順を行う

まとめ1

1, Reinstall MySQL Tools with the latest stable MySQL connector for windows.
2, Add this 3 files as reference in Visual Studio.
3, MySql.Data.dll
4, MySql.Data.Entity.EF6.dll
5, MySql.Web.dll
6, Modify following Web.config from

まとめ2

holidayprogramming.hatenablog.com

mysql-visualstudio-plugin-1.1.1.msiのインストール
mysql-connector-net-6.8.3.msiのインストール
NuGetパッケージの管理で以下をインストール
・EntityFramework (6.1.1)
・Mysql.Data (6.9.3)
・Mysql.Data.Entities (6.8.3.0)
・Mysql.Web (6.9.3)
手順3までの操作で Web.config (あるいはスタンドアロンAPなら App.config) が修正されます。
connectionStringタグを若干修正します。

※ダウンロード先
http://forums.mysql.com/read.php?174,601041,601041 http://dev.mysql.com/downloads/connector/net/6.8.html

参考サイト

Database First - EF6 | Microsoft Docs

データーモデル作成時によく発生するエラー

stackoverflow.com

互換性エラーが出た場合の解決策

qursaan-howto.blogspot.jp


以上

2018/06/14

Win10 & VS2017

stackoverflow.com

I have been fighting this fight for two weeks. I FINALLY found a combo of versions that works for me. The following was applied to a pristine re-image of my Win10 desktop two weeks ago. All patches were applied to system software before starting to deal with MySql.

Just this morning I re-read the post in this thread (MySql Forums): https://forums.mysql.com/read.php?174,659102,660369#msg-660369

I thought that I had tried those suggestions before but I must have messed up one of the versions. I think that poster's basic strategy is sound. In my case I uninstalled all local MySql parts and the installer.

I downloaded MySQL for Visual Studio - the Latest Development version (2.0.5 msi as of this writing) and installed that.

I found the OLD versions of the .Net Connector and installed 6.9.11

In VS 2017 I created a dummy project using .Net 4.6.1.

I applied pending VS updates.

I built the project.

I went to "Project -> Manage Nuget Packages" and installed / downgraded EntityFramework to 6.0.

I installed MySql.Data, MySql.Data.Entity and MySql.Web all at version 6.9.11

I cleaned and built the project then tried to add a new "Code First" model from a MySql DB... IT WORKED!


プライバシーポリシー