在EF中使用MySQL的方法及常見(jiàn)問(wèn)題
有時(shí)需要在網(wǎng)上租用空間或數(shù)據(jù)庫(kù),Mysql成本低一些,所以想將sql server轉(zhuǎn)成mysql……
注意:在安裝Mysql時(shí)要選擇文字集為utf8,否則將不能使用中文(當(dāng)前也可以在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)使用utf8,不過(guò)我不知道在ef生成數(shù)據(jù)庫(kù)時(shí)如何設(shè)置,希望高手指點(diǎn))
一、在項(xiàng)目中引用mysql的EF包
通過(guò)NuGet包管理器安裝:EntityFramework6.1.3、MySql.Data.Entity6.9.8
也可以用nuget的命令行加入:
Install-Package MySql.Data.Entity
二、新建相關(guān)類
1、新建 User 實(shí)體類
并定義實(shí)例的字段長(zhǎng)度,不定義的話會(huì)出現(xiàn)Specified key was too long;max key length is 767 bytes 的錯(cuò)誤,這是因?yàn)閟tring 類型直接映射到mysql 中的話是longtext,而mysql 支持最大長(zhǎng)度為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 類
并說(shuō)明用MySql進(jìn)行實(shí)現(xiàn) [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、寫(xiě)測(cè)試代碼
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>
最后,運(yùn)行程序,完成數(shù)據(jù)庫(kù)自動(dòng)創(chuàng)建
常見(jiàn)問(wèn)題
•出現(xiàn)錯(cuò)誤提示: Specified key was too long;max key length is 767 bytes
1)查看實(shí)體的字符串類型屬性是否設(shè)置了長(zhǎng)度
2)MyContext 類中是否聲明為生成為mysql 數(shù)據(jù)類型的 [DbConfigurationType(typeof(MySqlEFConfiguration))]
•出現(xiàn)錯(cuò)誤提示: Model compatibility cannot be checked because the database does not contain model metadata
刪除已生成的數(shù)據(jù)庫(kù)后重新運(yùn)行程序
•出現(xiàn)錯(cuò)誤提示:序列不包含任何匹配元素
檢查一下:
例如:1.
public class Employee { [Key] public int EmployeeId { get; set; } public string Name { get; set; } [ForeignKey("ManagerId")] public Employee Manager { get; set; } public int ManagerId { get; set; } }[ForeignKey("ManagerId")] public Employee Manager { get; set; } public int ManagerId { get; set; }這個(gè)外鍵設(shè)置。
2.[Column(TypeName="VARCHAR(254)")] public string ColumnName { get; set; } 這樣的定義,改成: [MaxLength(254)] [Column(TypeName="VARCHAR")] public string ColumnName { get; set; }3.(以下代碼未測(cè)試,因?yàn)槲也皇沁@樣用的,在下篇文章中將進(jìn)行測(cè)試)
modelBuilder.Entity<Category>() .HasKey(c => c.IdCategory ) .HasOptional(p => p.Children) .WithMany() .HasForeignKey(c => c.ChildrenId);
改成:
modelBuilder.Entity<Category>() .HasKey(c => c.IdCategory ) .HasMany(p => p.Children) .WithOptional() .HasForeignKey(c => c.ChildrenId);
.WithMany()換成.WithOptional()
以上所述是小編給大家介紹的在EF中使用MySQL的方法及常見(jiàn)問(wèn)題的全部敘述,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- MySQL無(wú)法啟動(dòng)幾種常見(jiàn)問(wèn)題小結(jié)
- 常見(jiàn)php與mysql中文亂碼問(wèn)題解決辦法
- MySQL 一次執(zhí)行多條語(yǔ)句的實(shí)現(xiàn)及常見(jiàn)問(wèn)題
- mysql安裝時(shí)出現(xiàn)各種常見(jiàn)問(wèn)題的解決方法
- CentOS下PHP7的編譯安裝及MySQL的支持和一些常見(jiàn)問(wèn)題的解決辦法
- mysql常見(jiàn)的錯(cuò)誤提示問(wèn)題處理小結(jié)
- Mysql常見(jiàn)問(wèn)題集錦
- 分享一下Mysql常見(jiàn)的幾個(gè)錯(cuò)誤問(wèn)題及解決方法
- mysql常見(jiàn)問(wèn)題解決
- MySQL使用的常見(jiàn)問(wèn)題解決與應(yīng)用技巧匯總
相關(guān)文章
MySQL for update鎖表還是鎖行校驗(yàn)(過(guò)程詳解)
在MySQL中,使用for update子句可以對(duì)查詢結(jié)果集進(jìn)行行級(jí)鎖定,以便在事務(wù)中對(duì)這些行進(jìn)行更新或者防止其他事務(wù)對(duì)這些行進(jìn)行修改,這篇文章主要介紹了MySQL for update鎖表還是鎖行校驗(yàn),需要的朋友可以參考下2024-02-02深入聊聊MySQL中各種對(duì)象的大小長(zhǎng)度限制
在使用mysql的過(guò)程中總會(huì)遇到或大或小的問(wèn)題,這篇文章主要給大家介紹了關(guān)于MySQL中各種對(duì)象的大小長(zhǎng)度限制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-12-12MySQL query_cache_type 參數(shù)與使用詳解
這篇文章主要介紹了MySQL query_cache_type參數(shù)介紹,需要的朋友可以參考下2021-07-07詳解MySQL存儲(chǔ)過(guò)程的創(chuàng)建和調(diào)用
這篇文章主要為大家介紹了MySQL存儲(chǔ)過(guò)程的創(chuàng)建和調(diào)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-12-12讀取mysql一個(gè)庫(kù)下面的所有的表table
本文給大家分享的是如何使用php實(shí)現(xiàn)讀取mysql一個(gè)庫(kù)下面的所有的表table的代碼,有需要的小伙伴可以參考下2016-12-12mysql 服務(wù)意外停止1067錯(cuò)誤解決辦法小結(jié)
今天在配置服務(wù)器時(shí)安裝mysql5.5總是無(wú)法安裝,查看日志錯(cuò)誤提示為1067錯(cuò)誤,下面來(lái)看我的解決辦法2012-11-11