Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/33.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
Asp.net 保持获取SqlException:无法在表';中插入标识列的显式值;电影';当IDENTITY_INSERT设置为OFF时_Asp.net_Sql Server_Asp.net Mvc_Visual Studio_Asp.net Core - Fatal编程技术网

Asp.net 保持获取SqlException:无法在表';中插入标识列的显式值;电影';当IDENTITY_INSERT设置为OFF时

Asp.net 保持获取SqlException:无法在表';中插入标识列的显式值;电影';当IDENTITY_INSERT设置为OFF时,asp.net,sql-server,asp.net-mvc,visual-studio,asp.net-core,Asp.net,Sql Server,Asp.net Mvc,Visual Studio,Asp.net Core,我正在开发一个程序,将excel文件导入SQL数据库。我使用的是EPPlus版本4.5.2.1。我在导入excel文件时不断出错。SqlException:当identity\u insert设置为OFF时,无法在表“Movie”中为identity列插入显式值。DbUpdateException:更新条目时出错。有关详细信息,请参见内部异常。 WebApplication14.Controllers.HomeController.Import(文件名)在HomeController.cs中 +

我正在开发一个程序,将excel文件导入SQL数据库。我使用的是EPPlus版本4.5.2.1。我在导入excel文件时不断出错。SqlException:当identity\u insert设置为OFF时,无法在表“Movie”中为identity列插入显式值。DbUpdateException:更新条目时出错。有关详细信息,请参见内部异常。 WebApplication14.Controllers.HomeController.Import(文件名)在HomeController.cs中 + wait_dbContext.saveChangesSync()

HomeController代码:

namespace WebApplication14.Controllers
{
    public class HomeController : Controller
    {
        private readonly ApplicationDbContext _dbContext;
        public HomeController(ApplicationDbContext dbContext)
        {
            _dbContext = dbContext;
        }
        public async Task<List<Movie>> Import(IFormFile file)
        {
            var list = new List<Movie>();
            using (var stream = new MemoryStream())
            {
                await file.CopyToAsync(stream);
                using (var package = new ExcelPackage(stream))
                {

                    ExcelWorksheet worksheet = package.Workbook.Worksheets[0];
                    var rowcount = worksheet.Dimension.Rows;
                    var colcount = worksheet.Dimension.Columns;

                    for (int row = 2; row < rowcount; row++)
                    {
                        list.Add(new Movie
                        {
                            Id = int.Parse(worksheet.Cells[row, 1].Value.ToString().Trim()),
                            Title = worksheet.Cells[row, 2].Value.ToString().Trim(),
                            Genre = worksheet.Cells[row, 3].Value.ToString().Trim()
                        });
                    }
                }
            }
            //SaveDataToDb(list);
            _dbContext.Movie.AddRange(list);
            await _dbContext.Database.ExecuteSqlCommandAsync(@"SET IDENTITY_INSERT [MovieList-1].[dbo].[Movie] ON");
            await _dbContext.SaveChangesAsync();
            await _dbContext.Database.ExecuteSqlCommandAsync(@"SET IDENTITY_INSERT [MovieList-1].[dbo].[Movie] OFF");

            return list;


        }

        public IActionResult Index()
        {
            return View();
        }

        public IActionResult Privacy()
        {
            return View();
        }

        [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
        public IActionResult Error()
        {
            return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
        }
    }
}
DbContext代码

namespace WebApplication14.Models
{
    public class ApplicationDbContext : DbContext
    {
        public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options) : base(options)
        {

        }

        public DbSet<Movie> Movie { get; set; }
    }
}
查看/主页/索引

@{
    ViewData["Title"] = "Home Page";
}

<div class="text-center">
    <h1 class="display-4">Welcome</h1>
    <p>Learn about <a href="https://docs.microsoft.com/aspnet/core">building Web apps with ASP.NET Core</a>.</p>
    <div class="container">
        <form method="post" asp-controller="Home" asp-action="Import" enctype="multipart/form-data">
            <input type="file" name="file" />
            <button type="submit">Import From Excel</button>
        </form>
    </div>
</div>
@{
ViewData[“Title”]=“主页”;
}
欢迎
了解

从Excel导入
默认情况下,EF将在每次操作后打开和关闭连接。这会导致SqlConnection返回到连接池,并且每次从连接池中提取时,其状态都会被清除,包括删除临时表和重置会话级别集设置

如果显式打开DbContext的连接(或启动事务),则在调用SaveChanges()时,IDENTITY_INSERT设置仍应有效:


默认情况下,EF将在每次操作后打开和关闭连接。如果显式打开连接,它将在DbContext期间保持打开状态。是否应删除await_DbContext.Database.ExecuteSqlCommandAsync(@“SET IDENTITY_INSERT[MovieList-1].[dbo].[Movie]OFF”);?或者我需要在AppultBuffice中设置一些东西吗?我知道已经有答案了,但是我想你应该告诉我们,或者考虑一下,你是否真的需要插入这些ID。因为如果它们不包含身份信息,就不应该设置它们并允许生成ID。但是如果您知道所有这些ID都是数据库中的现有实体,那么实际上您不应该使用
Add()
;您应该改用
\u dbContext.Entry(movie.State=EntityState.Modified
。这将附加实体,并确保所有属性都将写入数据库。谢谢,我现在就试试!让您知道发生了什么情况我一直在_dbContext.Database.Connection.Open()中的Connection下收到错误;我需要在NuGet PM中安装任何东西吗?NVM代码正常工作我想他们更改了连接。Open()到OpenConnection(),现在也正常工作了我忘记连接SQL Server对象Explore->Add SQL Server Lol这是EF Core vs EF6。
public partial class MoviesToDb : Migration
    {
        protected override void Up(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.CreateTable(
                name: "Movie",
                columns: table => new
                {
                    Id = table.Column<int>(nullable: false)
                        .Annotation("SqlServer:Identity", "1, 1"),
                    Title = table.Column<string>(nullable: true),
                    Genre = table.Column<string>(nullable: true)
                },
                constraints: table =>
                {
                    table.PrimaryKey("PK_Movie", x => x.Id);
                });
        }

        protected override void Down(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.DropTable(
                name: "Movie");
        }
    }
}
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddControllersWithViews();
            services.AddDbContext<ApplicationDbContext>(options =>
               options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
            services.Configure<CookiePolicyOptions>(options =>
            {
                // This lambda determines whether user consent for non-essential cookies is needed for a given request.
                options.CheckConsentNeeded = context => true;
                options.MinimumSameSitePolicy = SameSiteMode.None;
            });

        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            else
            {
                app.UseExceptionHandler("/Home/Error");
                // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
                app.UseHsts();
            }
            app.UseHttpsRedirection();
            app.UseStaticFiles();

            app.UseRouting();

            app.UseAuthorization();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllerRoute(
                    name: "default",
                    pattern: "{controller=Home}/{action=Index}/{id?}");
            });
        }
    }
}
 "ConnectionStrings": {
    "DefaultConnection": "Server=localhost\\SQLEXPRESS;Database=MovieList-1;Trusted_Connection=True;MultipleActiveResultSets=true"
  },
@{
    ViewData["Title"] = "Home Page";
}

<div class="text-center">
    <h1 class="display-4">Welcome</h1>
    <p>Learn about <a href="https://docs.microsoft.com/aspnet/core">building Web apps with ASP.NET Core</a>.</p>
    <div class="container">
        <form method="post" asp-controller="Home" asp-action="Import" enctype="multipart/form-data">
            <input type="file" name="file" />
            <button type="submit">Import From Excel</button>
        </form>
    </div>
</div>
    _dbContext.Database.OpenConnection();
    _dbContext.Movie.AddRange(list);
    await _dbContext.Database.ExecuteSqlCommandAsync(@"SET IDENTITY_INSERT [MovieList-1].[dbo].[Movie] ON");
    await _dbContext.SaveChangesAsync();
    await _dbContext.Database.ExecuteSqlCommandAsync(@"SET IDENTITY_INSERT [MovieList-1].[dbo].[Movie] OFF");