dotConnect for QuickBooks Online Documentation
Devart.Data.QuickBooks Namespace / QuickBooksCommandBuilder Class / KeyFields Property
Example

KeyFields Property (QuickBooksCommandBuilder)
Gets or sets string containing list of key field names separated by semicolon. They are used to generate update commands.
Syntax
'Declaration
 
Public Shadows Property KeyFields As String
 

Property Value

The string containing list of key field names separated by semicolon.
Remarks

This property is used when the ConflictOption property is set to OverwriteChanges, otherwise all columns will be used in the WHERE clause.

If KeyFields is nonempty, its value is used as the list of columns for the WHERE clause. If KeyFields is empty, the primary key columns are used.

Example
The following example demonstrates how UPDATE and DELETE statements are generated.
public void UseKeyFields(string connectionString) {

        QuickBooksConnection conn = new QuickBooksConnection(connectionString);
        conn.Open();

        QuickBooksDataAdapter adapter = new QuickBooksDataAdapter("SELECT * FROM Customer", conn);
        QuickBooksCommandBuilder commBuilder = new QuickBooksCommandBuilder(adapter);

        commBuilder.ConflictOption = ConflictOption.OverwriteChanges;

        commBuilder.KeyFields = "Id, DisplayName";

        string updateComm = commBuilder.GetUpdateCommand().CommandText;
        string deleteComm = commBuilder.GetDeleteCommand().CommandText;

        Console.WriteLine(updateComm);
        Console.WriteLine(deleteComm);
        conn.Close();
}
Public Sub UseKeyFields(ByVal connectionString As String)
        Dim conn As QuickBooksConnection = New QuickBooksConnection(connectionString)
        conn.Open()

        Dim adapter As QuickBooksDataAdapter = New QuickBooksDataAdapter("SELECT * FROM Customer", conn)
        Dim commBuilder As QuickBooksCommandBuilder = New QuickBooksCommandBuilder(adapter)

        commBuilder.ConflictOption = ConflictOption.OverwriteChanges

        commBuilder.KeyFields = "Id, DisplayName"

        Dim updateComm As String = commBuilder.GetUpdateCommand().CommandText
        Dim deleteComm As String = commBuilder.GetDeleteCommand().CommandText

        Console.WriteLine(updateComm)
        Console.WriteLine(deleteComm)
        conn.Close()
End Sub
Requirements

Target Platforms: Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

See Also