《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的方法及常见问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)