国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

在EF中使用MySQL的方法及常見問題

2024-07-24 12:54:04
字體:
來源:轉載
供稿:網友

有時需要在網上租用空間或數據庫,Mysql成本低一些,所以想將sql server轉成mysql……

注意:在安裝Mysql時要選擇文字集為utf8,否則將不能使用中文(當前也可以在創建數據庫時使用utf8,不過我不知道在ef生成數據庫時如何設置,希望高手指點)

一、在項目中引用mysql的EF包

通過NuGet包管理器安裝:EntityFramework6.1.3、MySql.Data.Entity6.9.8

也可以用nuget的命令行加入:

Install-Package MySql.Data.Entity

二、新建相關類

1、新建 User 實體類

并定義實例的字段長度,不定義的話會出現Specified key was too long;max key length is 767 bytes 的錯誤,這是因為string 類型直接映射到mysql 中的話是longtext,而mysql 支持最大長度為767 bytes.

public class User{public int Id { get; set; }[StringLength(30)]public string UserName { get; set; }[MaxLength(30)]public string PassWord { get; set; } }

2、新建 MyContext 類

并說明用MySql進行實現 [DbConfigurationType(typeof(MySqlEFConfiguration))]

[DbConfigurationType(typeof(MySqlEFConfiguration))]public class MyContext : DbContext{public MyContext(): base("name=MyContext")//web.config中connectionstring的名字{}public DbSet<User> Users { get; set; }}

3、寫測試代碼

Database.SetInitializer(new DropCreateDatabaseIfModelChanges<MyContext>());var context = new MyContext();//插入一行值context.Users.Add(new User { UserName = "EF6MySQL" });context.SaveChanges();

三、配置Web.config

在<connectionStrings>中加入以下代碼:

<add name="MyContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=MySQL_EF;user id=root;password=root;" providerName="MySql.Data.MySqlClient" />

完整的web.config如下:

<?xml version="1.0" encoding="utf-8"?><configuration><configSections><!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 --><section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" /></configSections><entityFramework><defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory , EntityFramework" /><providers><provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" /><provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.9.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider></providers></entityFramework><system.data><DbProviderFactories><remove invariant="MySql.Data.MySqlClient" /><add name="MySQL Data Provider" invariant="MySql.Data.MySqlClient" description=".Net Framework Data Provider for MySQL" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.9.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" /></DbProviderFactories></system.data><connectionStrings><add name="MyContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=MySQL_EF;user id=root;password=root;" providerName="MySql.Data.MySqlClient" /></connectionStrings></configuration>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 平湖市| 滦平县| 德清县| 腾冲县| 南投县| 台安县| 乌恰县| 随州市| 犍为县| 息烽县| 渝北区| 遂川县| 绥德县| 赤壁市| 红桥区| 湟中县| 马尔康县| 大埔县| 洪洞县| 旺苍县| 屏东县| 太和县| 九寨沟县| 海口市| 板桥市| 喀喇沁旗| 固镇县| 罗平县| 平果县| 大理市| 昌图县| 田阳县| 石城县| 铅山县| 扎兰屯市| 舞钢市| 射洪县| 桐梓县| 渑池县| 鄂州市| 色达县|