Alles, was Sie tun müssen, ist eine neue Instanz der Klasse zu erstellen und dann rufen InsertOnSumbit() auf dem Tisch:
var foo = new MyFoo { Name = "foo1" };
var dc = new MyDataContext();
dc.Foos.InsertOnSubmit(foo);
dc.SubmitChanges();
die andere Sache, die Sie sicher sein müssen, ist, wie Sie Ihre ID-Spalte sind erhöht wird. Im Allgemeinen stelle ich immer sicher, dass ich die IDENTITY (1,1) -Einstellung für meine ID-Spalten verwende. Dies wird auf Ihrer LINQ Unternehmens-ID-Spalte erklärt wie folgt:
[Column(AutoSync = AutoSync.OnInsert, IsPrimaryKey = true, IsDbGenerated = true)]
public Int32 Id { get; set; }
Um Duplikate zu vermeiden, was Sie wirklich brauchen, ist, was wir in meinem Geschäft nennen eine „anhängen“ -Funktionalität. IMHO ist dies am einfachsten mit einer gespeicherten Prozedur ausgeführt - wir sogar eine Vorlage haben wir dafür verwenden:
USE [<Database_Name, sysobject, Database_Name>]
GO
CREATE PROCEDURE [<Schema, sysobject, dbo>].[<Table_Name, sysobject, Table_Name>__append]
(
@id INT OUTPUT,
@<Key_Param, sysobject, Key_Param> <Key_Param_Type, sysobject, VARCHAR(50)>
)
AS
BEGIN
SELECT @id = [id] FROM [<Schema, sysobject, dbo>].[<Table_Name, sysobject, Table_Name>s] (NOLOCK) WHERE [<Key_Param, sysobject, Key_Param>] = @<Key_Param, sysobject, Key_Param>
IF @id IS NULL
BEGIN
INSERT INTO [<Schema, sysobject, dbo>].[<Table_Name, sysobject, Table_Name>s] ([<Key_Param, sysobject, Key_Param>])
OUTPUT INSERTED.[id] INTO @inserted_ids
VALUES (@<Key_Param, sysobject, Key_Param>)
SELECT TOP 1 @id = [id] FROM @inserted_ids;
END
ELSE
BEGIN
UPDATE [<Schema, sysobject, dbo>].[<Table_Name, sysobject, Table_Name>s]
SET
[<Key_Param, sysobject, Key_Param>] = @<Key_Param, sysobject, Key_Param>
WHERE [id] = @id
END
END
GO
Es ist möglich, es in Linq zu tun, obwohl, fragt nur für eine Liste der vorhandenen IDs (oder was auch immer Spalte Sie Keying off von):
var dc = new MyDataContext();
var existingFoos = dc.Foos.ToList();
var newFoos = new List<Foo>();
foreach(var bar in whateverYoureIterating) {
// logic to add to newFoos
}
var foosToInsert = newFoos.Where(newFoo => !existingFoos.Any(existingFoo => newFoo.Id == existingFoo.Id));
dc.Foos.InsertAllOnSubmit(foosToInsert);
dc.SubmitChanges();
// use the next line if you plan on re-using existingFoos. If that's the case I'd wrap dc.SubmitChanges() in a try-catch as well.
existingFoos.AddRange(foosToInsert);
warten auf Ihre Bearbeitung ... –
Die LINQ-Lösung scheint ziemlich langsam. Die Abfrage eines riesigen Tisches und das Laden der Inhalte in den Speicher scheint für mich undurchführbar. Vielleicht sollte ich beim SP-Ansatz bleiben. –
Das ist, was ich dachte ... Obwohl, Sie könnten die LINQ-Lösung beschleunigen, indem Sie nur die Eigenschaften auswählen, die Sie wirklich brauchen ... zum Beispiel nur die ID-Spalte. Wenn Sie die "vorhandene" Abfrage für mehrere Durchläufe erneut verwenden können, wird das ebenfalls hilfreich sein. –