当前位置:Gxlcms > mysql > 在EF中使用MySQL的方法及常见问题

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

时间:2021-07-01 10:21:17 帮助过:58人阅读

有时需要在网上租用空间或数据库,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.

  1. public class User
  2. {
  3. public int Id { get; set; }
  4. [StringLength(30)]
  5. public string UserName { get; set; }
  6. [MaxLength(30)]
  7. public string PassWord { get; set; } }

2、新建 MyContext 类

并说明用MySql进行实现 [DbConfigurationType(typeof(MySqlEFConfiguration))]

  1. [DbConfigurationType(typeof(MySqlEFConfiguration))]
  2. public class MyContext : DbContext
  3. {
  4. public MyContext()
  5. : base("name=MyContext")//web.config中connectionstring的名字
  6. {
  7. }
  8. public DbSet<User> Users { get; set; }
  9. }

3、写测试代码

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

三、配置Web.config

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

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

完整的web.config如下:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <configuration>
  3. <configSections>
  4. <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
  5. <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  6. </configSections>
  7. <entityFramework>
  8. <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory , EntityFramework" />
  9. <providers>
  10. <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
  11. <provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.9.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d">
  12. </provider>
  13. </providers>
  14. </entityFramework>
  15. <system.data>
  16. <DbProviderFactories>
  17. <remove invariant="MySql.Data.MySqlClient" />
  18. <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" />
  19. </DbProviderFactories>
  20. </system.data>
  21. <connectionStrings>
  22. <add name="MyContext" connectionString="Data Source=localhost;port=3306;Initial Catalog=MySQL_EF;user id=root;password=root;" providerName="MySql.Data.MySqlClient" />
  23. </connectionStrings>
  24. </configuration>

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

常见问题

•出现错误提示: 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.

  1. public class Employee
  2. {
  3. [Key]
  4. public int EmployeeId { get; set; }
  5. public string Name { get; set; }
  6. [ForeignKey("ManagerId")]
  7. public Employee Manager { get; set; }
  8. public int ManagerId { get; set; }
  9. }[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.(以下代码未测试,因为我不是这样用的,在下篇文章中将进行测试)

  1. modelBuilder.Entity<Category>()
  2. .HasKey(c => c.IdCategory )
  3. .HasOptional(p => p.Children)
  4. .WithMany()
  5. .HasForeignKey(c => c.ChildrenId);

改成:

  1. modelBuilder.Entity<Category>()
  2. .HasKey(c => c.IdCategory )
  3. .HasMany(p => p.Children)
  4. .WithOptional()
  5. .HasForeignKey(c => c.ChildrenId);

.WithMany()换成.WithOptional()

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

您可能感兴趣的文章:

  • MySQL无法启动几种常见问题小结
  • 常见php与mysql中文乱码问题解决办法
  • MySQL 一次执行多条语句的实现及常见问题
  • mysql安装时出现各种常见问题的解决方法
  • CentOS下PHP7的编译安装及MySQL的支持和一些常见问题的解决办法
  • mysql常见的错误提示问题处理小结
  • Mysql常见问题集锦
  • 分享一下Mysql常见的几个错误问题及解决方法
  • mysql常见问题解决
  • MySQL使用的常见问题解决与应用技巧汇总

人气教程排行