1

我只是想尝试使用实体框架来代替 NHibernate。我正在使用 MySql 数据库。所以我对代码优先系统做了一些测试。MsSql 数据库一切正常,并且模式是自动生成的。但是后来我用 MySql 进行了尝试,但模式生成不起作用。

public class Context : DbContext
{
    public Context()
    {

    }

    public Context(string str)
        : base (str)
    {

    }

    public DbSet<User> Users
    {
        get;
        set;
    }
}

public class User
{
    public int Id
    {
        get;
        set;
    }

    public string Name
    {
        get;
        set;
    }
}

class Program
{
    static void Main(string[] args)
    {
      var sqlBuilder =
            new SqlConnectionStringBuilder
            {
                DataSource = "localhost",
                InitialCatalog = "test",
                Password = "",
                UserID = "root"
            };

        var entityBuilder =
            new EntityConnectionStringBuilder
            {
                Provider = "MySql.Data.MySqlClient",
                ProviderConnectionString = sqlBuilder.ConnectionString,
                Metadata = @"res://*"
            };

        var str = entityBuilder.ConnectionString;

        using (var ctx = new Context(str)) 
        {

            ctx.Users.Add(new User() // exception here
            {
                Name = "test"
            });

            ctx.SaveChanges();
        }

        using (var ctx = new Context(str))
        {
            foreach (var user in ctx.Users)
            {
                Console.WriteLine("id:{0} name:{1}", user.Id, user.Name);
            }
        }
    }
}

我得到了这个例外:“实体类型 User 不是当前上下文模型的一部分。”

所以这是我的问题,如果我使用 MySql 可以自动生成数据库吗?

4

1 回答 1

0

我不知道为什么它有效,但现在有效。我从代码中删除了连接属性,并创建了一个 app.config 文件并使用此博客http://brice-lambson.blogspot.fr/2012/05/using-entity-framework更正了数据库创建中的错误-code-first-with.html现在它可以工作了

于 2012-08-02T09:59:57.593 回答