Asp.net 保持获取SqlException:无法在表';中插入标识列的显式值;电影';当IDENTITY_INSERT设置为OFF时
我正在开发一个程序,将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代码: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中 +
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");