在 SQL Server 2008 中,有没有办法在插入行的同时忽略那些导致外键约束失败的行?
例如,我有一个类似于这样的插入语句:
insert into tblFoo(id, name, parent_id, desc) values
(1, 'a', 1, null),
(2, 'c', 3, 'blah'),
....;
parent_id 是另一个表的 fk。然后我怎样才能让 sql server 跳过 fk 列无效的行?
更新我想让它自动工作,而不必先过滤掉那些违反 fk 约束的行。原因是插入语句是由程序生成的,因此事先不知道每个表上存在哪些外键。