Mysql应用在EF中使用MySQL的方法及常见问题

Mysql应用在EF中使用MySQL的方法及常见问题,第1张

概述介绍《Mysql应用在EF中使用MySQL的方法常见问题》开发教程,希望对您有用。

《MysqL应用在EF中使用MysqL的方法及常见问题》要点:
本文介绍了MysqL应用在EF中使用MysqL的方法及常见问题,希望对您有用。如果有疑问,可以联系我们。

有时需要在网上租用空间或数据库,MysqL成本低一些,所以想将sql server转成MysqL……
MysqL教程

注意:在安装MysqL时要选择文字集为utf8,否则将不能使用中文(当前也可以在创建数据库时使用utf8,不过我不知道在ef生成数据库时如何设置,希望高手指点)
MysqL教程

一、在项目中引用MysqL的EF包
MysqL教程

通过NuGet包管理器安装:EntityFramework6.1.3、mysql.data.Entity6.9.8
MysqL教程

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

Install-Package mysql.data.Entity
MysqL教程

二、新建相关类
MysqL教程

1、新建 User 实体类
MysqL教程

并定义实例的字段长度,不定义的话会出现SpecifIEd key was too long;max key length is 767 bytes 的错误,这是因为string 类型直接映射到MysqL 中的话是longtext,而MysqL 支持最大长度为767 bytes.
MysqL教程

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

并说明用MysqL进行实现 [DbConfigurationType(typeof(MysqLEFConfiguration))]MysqL教程

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

3、写测试代码
MysqL教程

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

三、配置Web.config
MysqL教程

在<connectionStrings>中加入以下代码:MysqL教程

<add name="MyContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=MysqL_EF;user ID=root;password=root;" provIDername="mysql.data.MysqLClIEnt" />

完整的web.config如下:
MysqL教程

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

最后,运行程序,完成数据库自动创建
MysqL教程

常见问题
MysqL教程

•出现错误提示: SpecifIEd key was too long;max key length is 767 bytesMysqL教程

1)查看实体的字符串类型属性是否设置了长度
MysqL教程

2)MyContext 类中是否声明为生成为MysqL 数据类型的 [DbConfigurationType(typeof(MysqLEFConfiguration))]
MysqL教程

•出现错误提示: Model compatibility cannot be checked because the database does not contain model Metadata
MysqL教程

删除已生成的数据库后重新运行程序
MysqL教程

•出现错误提示:序列不包含任何匹配元素
MysqL教程

检查一下:MysqL教程

例如:1.MysqL教程

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; }这个外键设置. 

2.[Column(Typename="VARCHAR(254)")] public string Columnname { get; set; } 这样的定义,改成: [MaxLength(254)] [Column(Typename="VARCHAR")] public string Columnname { get; set; }3.(以下代码未测试,因为我不是这样用的,在下篇文章中将进行测试)MysqL教程

modelBuilder.Entity<@R_502_4602@>().HasKey(c => c.ID@R_502_4602@ ).HasOptional(p => p.Children).WithMany().HasForeignKey(c => c.ChildrenID);

改成:MysqL教程

modelBuilder.Entity<@R_502_4602@>().HasKey(c => c.ID@R_502_4602@ ).HasMany(p => p.Children).WithOptional().HasForeignKey(c => c.ChildrenID);

.WithMany()换成.WithOptional()MysqL教程

以上所述是小编给大家介绍的在EF中使用MysqL的方法及常见问题的全部叙述,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的.在此也非常感谢大家对内存溢出PHP网站的支持!MysqL教程

总结

以上是内存溢出为你收集整理的Mysql应用在EF中使用MySQL的方法及常见问题全部内容,希望文章能够帮你解决Mysql应用在EF中使用MySQL的方法及常见问题所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1162280.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存