ef for mysql_Mysql应用在EF中使用MySQL的方法及常见问题

《MysqL应用在EF中使用MysqL的方法及常见问题》要点:

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

有时需要在网上租用空间或数据库,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 Users { get; set; }

}

3、写测试代码

Database.SetInitializer(new DropCreateDatabaseIfModelChanges());

var context = new MyContext();

//插入一行值

context.Users.Add(new User { UserName = "EF6MysqL" });

context.SaveChanges();

三、配置Web.config

在中加入以下代码:

完整的web.config如下:

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

常见问题

•出现错误提示: Specified key was too long;max key length is 767 bytes

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

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

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

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

检查一下:

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

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

modelBuilder.Entity()

.HasKey(c => c.IdCategory )

.HasOptional(p => p.Children)

.WithMany()

.HasForeignKey(c => c.ChildrenId);

改成:

modelBuilder.Entity()

.HasKey(c => c.IdCategory )

.HasMany(p => p.Children)

.WithOptional()

.HasForeignKey(c => c.ChildrenId);

.WithMany()换成.WithOptional()

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

总结

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

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值