Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/asp.net-mvc-3/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Database 将实体映射到ASPNETDB.MDF MVC3_Database_Asp.net Mvc 3_Entity Framework - Fatal编程技术网

Database 将实体映射到ASPNETDB.MDF MVC3

Database 将实体映射到ASPNETDB.MDF MVC3,database,asp.net-mvc-3,entity-framework,Database,Asp.net Mvc 3,Entity Framework,为了避免有两个数据库,我将我的实体映射到ASPNETDB.MDF,它是自动为成员身份而创建的。我阅读本文是为了将我的实体映射到现有数据库: 据我所知,我只需要更改上下文类的数据库名称,如下所示: using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Data.Entity; using UniversityApp.Models; using System.

为了避免有两个数据库,我将我的实体映射到ASPNETDB.MDF,它是自动为成员身份而创建的。我阅读本文是为了将我的实体映射到现有数据库: 据我所知,我只需要更改上下文类的数据库名称,如下所示:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using UniversityApp.Models;
using System.Data.Entity.ModelConfiguration.Conventions;


namespace UniversityApp.DAL
{
        public class ASPNETDB : DbContext
        {
            public DbSet<User> Users { get; set; }
            public DbSet<Review> Reviews { get; set; }
            public DbSet<Movie> Movies { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
        }

    }
}
<connectionStrings>
    <add name="ApplicationServices"    connectionString="data source=.\SQLEXPRESS Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true"     providerName="System.Data.SqlClient" />
<add name="MovieContext" connectionString="Data Source=|DataDirectory|aspnetdb.mdf"     providerName="System.Data.SqlServerCe.4.0"/>
</connectionStrings>
我还更改了连接字符串,如下所示:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using UniversityApp.Models;
using System.Data.Entity.ModelConfiguration.Conventions;


namespace UniversityApp.DAL
{
        public class ASPNETDB : DbContext
        {
            public DbSet<User> Users { get; set; }
            public DbSet<Review> Reviews { get; set; }
            public DbSet<Movie> Movies { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
        }

    }
}
<connectionStrings>
    <add name="ApplicationServices"    connectionString="data source=.\SQLEXPRESS Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true"     providerName="System.Data.SqlClient" />
<add name="MovieContext" connectionString="Data Source=|DataDirectory|aspnetdb.mdf"     providerName="System.Data.SqlServerCe.4.0"/>
</connectionStrings>

对旧数据库的读取和写入,甚至对初始化数据,一切似乎都很好。但是,当我打开到ASPNETDB.mdf的连接时,仍然没有看到我的表。我做错了什么?

我想你会在这里遇到更多的问题,一般来说,这可能不是目前最好的方法。也就是说,为了回答您的实际问题,DbContext正在寻找一个与您的上下文同名的连接字符串。也就是说,它正在查找名为ASPNETDB的连接字符串。因为您的连接字符串命名为ApplicationServices,而MovieContext DbContext找不到其中任何一个

要使DbContext使用特定的连接字符串,只需将该连接字符串传递给DbContext构造函数。例如:

public class ASPNETDB : DbContext 
{
    public ASPNETDB()
     : base("name=ApplicationServices")
    {
    }
    ...
}

一旦实现了这一点,您可能会考虑使用迁移在已经存在的数据库中创建表。

为什么需要其他数据库或aspnetdb.mdf中的成员资格表?您可以将ASP.NET成员资格/角色/配置文件添加到任何现有数据库。只需使用reg_sql.exe指定-d标志,是否需要修改我的连接字符串?根据给定的信息不可能这么说。第二个似乎指定了一个mdf文件,但使用了SQL Compact,这要么是错误的,要么是误导性很强,但我对您实际做的事情了解不够,无法真正有意义地进行评论。