加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2020-12-12 01:09:08 所属栏目:MySql教程 来源:网络整理
导读:《Mysql应用在EF中使用MySQL的方法及常见问题》要点: 本文介绍了Mysql应用在EF中使用MySQL的方法及常见问题,希望对您有用。如果有疑问,可以联系我们。 有时需要在网上租用空间或数据库,Mysql成本低一些,所以想将sql server转成mysql…… 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<Category>()
.HasKey(c => c.IdCategory )
.HasOptional(p => p.Children)
.WithMany()
.HasForeignKey(c => c.ChildrenId);

改成:MYSQL教程

modelBuilder.Entity<Category>()
.HasKey(c => c.IdCategory )
.HasMany(p => p.Children)
.WithOptional()
.HasForeignKey(c => c.ChildrenId);

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读