首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

批量insert,该如何解决

2013-03-01 
批量insert/// summary/// 专辑文档添加/// 被引用:AdminController.LibIndex:Post/// /summary/// p

批量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生成的数据库不会出这种低级问题
[解决办法]
建议在插入数据的时候先检查一下外键约束是否符合;如果没多大必要的话可以将外键去掉,不加外键

热点排行