dotConnect for Salesforce Documentation
Devart.Data.Salesforce Namespace / SalesforceCommandBuilder Class / KeyFields Property
Example

In This Topic
    KeyFields Property (SalesforceCommandBuilder)
    In This Topic
    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
    public new string KeyFields {get; set;}

    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) {
    
            SalesforceConnection conn = new SalesforceConnection(connectionString);
            conn.Open();
    
            SalesforceDataAdapter adapter = new SalesforceDataAdapter("SELECT * FROM Account", conn);
            SalesforceCommandBuilder commBuilder = new SalesforceCommandBuilder(adapter);
    
            commBuilder.ConflictOption = ConflictOption.OverwriteChanges;
    
            commBuilder.KeyFields = "Id, Name";
    
            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 SalesforceConnection = New SalesforceConnection(connectionString)
            conn.Open()
    
            Dim adapter As SalesforceDataAdapter = New SalesforceDataAdapter("SELECT * FROM Account", conn)
            Dim commBuilder As SalesforceCommandBuilder = New SalesforceCommandBuilder(adapter)
    
            commBuilder.ConflictOption = ConflictOption.OverwriteChanges
    
            commBuilder.KeyFields = "Id, Name"
    
            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