批量insert
/// <summary>
/// 专辑文档添加
/// 被引用:AdminController.LibIndex:Post
/// </summary>
/// <param name="guidArr">文章Guid数组</param>
/// <param name="newAlbId">专辑ID</param>
public static void DocAddToAlb(string[] guidArr, int newAlbId)
{
using (var db = new WEBVODEntities())
{
for (int i = 0; i < guidArr.Length; i++)
{
LibAlbumDoc albumDoc = new LibAlbumDoc();
albumDoc.LibGuid = guidArr[i];
albumDoc.AlbumId = newAlbId;
albumDoc.PubDate = DateTime.Now;
albumDoc.LoginName = "admin"; //!!!用户名,以后要修改的。
db.LibAlbumDoc.AddObject(albumDoc);
}
db.SaveChanges(); //在这里就错误了。
}
}
错误信息:
INSERT 语句与 FOREIGN KEY 约束"FK_LibAlbumDoc_Library"冲突。该冲突发生于数据库"WEBVOD",表"dbo.Library", column 'Guid'。
语句已终止。
说明: 执行当前 Web 请求期间,出现未经处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。
异常详细信息: System.Data.SqlClient.SqlException: INSERT 语句与 FOREIGN KEY 约束"FK_LibAlbumDoc_Library"冲突。该冲突发生于数据库"WEBVOD",表"dbo.Library", column 'Guid'。
语句已终止。
源错误:
行 407: db.LibAlbumDoc.AddObject(albumDoc);
行 408: }
行 409: db.SaveChanges();
行 410: }
行 411:
源文件: F:\win2008iis\BYVOD\Models\LibraryBLL.cs 行: 409
------解决方案--------------------
错误说的很清楚了,违反了外键约束
[解决办法]
你的数据库表的id是guid类型,而程序传入的参数是string类型,未经转换成guid类型就传入了,造成错误。
以上仅仅是一种可能,具体要看你的程序是怎么写的了
[解决办法]
貌似你的实体都是设计出来的啊?
LZ去看看EF的CodeFirst吧
用CodeFirst生成的数据库不会出这种低级问题
[解决办法]
建议在插入数据的时候先检查一下外键约束是否符合;如果没多大必要的话可以将外键去掉,不加外键