tMSSqlOutputBulkExec
Gains in performance during Insert operations to a Microsoft SQL Server database.
The tMSSqlOutputBulk and tMSSqlBulkExec components are used together in a two step process. In the first step, an output file is generated. In the second step, this file is used in the INSERT operation used to feed a database. These two steps are fused together in the tMSSqlOutputBulkExec component.
tMSSqlOutputBulkExec Standard properties
These properties are used to configure tMSSqlOutputBulkExec running in the Standard Job framework.
The Standard tMSSqlOutputBulkExec component belongs to the Databases family.
The component in this framework is available in all Talend products.
Basic settings
| Properties | Description | 
|---|---|
| Database | Select the desired database type from the list and click Apply. | 
| Action | Select the action to be carried out Bulk insert Bulk update | 
| Property type | Either Built-in or
                        Repository
                  . 
 | 
| Use an existing connection | Select this check box and in the Component List drop-down list, select the desired connection component to reuse the connection details you already defined. Information noteNote: When a Job contains the parent Job and the child Job, do the following if you
         want to share an existing connection between the parent Job and the child Job (for example,
         to share the connection created by the parent Job with the child Job).  
 For an example about how to share a database connection across Job levels, see Sharing a database connection. | 
| JDBC Provider | Select the provider of the JDBC driver to be used, either Microsoft (the default, recommended) or Open source JTDS. When Microsoft is selected, you need to download the Microsoft JDBC Driver for SQL Server on Microsoft Download Center, unpack the downloaded zip file, choose a jar in the unzipped folder based on your JRE version, rename the jar to mssql-jdbc.jar and install it manually. For more information about choosing the jar, see the System Requirements information on Microsoft Download Center. Note that OSGi builds will not include any open source jTDS JDBC driver. If you need to build your Job containing this component as an OSGi bundle, use the official Microsoft JDBC driver; otherwise, this component will work only with Datasource with the jTDS JDBC driver properly installed in Talend Runtime. | 
| Host | Enter the IP address or the hostname of the database server or the
                     Azure Synapse Analytics to be used. If the SQL Server Browser service is running on the machine where the server resides, you can connect to a named instance through a TCP dynamic port by providing the host name and the instance name in this field in the format of {host_name}\{instance_name}. In this case, you can leave the Port field empty. See SQL Server Browser service for related information. Currently, only localhost, 127.0.0.1 or the exact IP address of the local machine is allowed for proper functioning. In other words, the database server must be installed on the same machine where Talend Studio is installed or where the Job using tMSSqlOutputBulkExec is deployed. | 
| Port | Enter the listening port number of the database server or the Azure Synapse Analytics to be used. If the SQL Server Browser service is running on the machine where the server resides, you can connect to a named instance through a TCP dynamic port by providing the host name and the instance name in the Host field and leave this field empty. See SQL Server Browser service for related information. | 
| DB name | Enter the name of the database | 
| Schema | Enter the name of the database schema. | 
| Username and Password | Enter the authentication data. To enter the password, click the [...] button next to the Password field, enter the password in double quotes in the pop-up dialog box, and then click OK. You can use Type 2 integrated authentication on Windows by adding integratedSecurity=true in the Additional JDBC Parameters field and leave these two fields empty. See section Connecting with integrated authentication On Windows at Building the connection URL for related information. | 
| Table | Name of the table to be written. Note that only one table can be written at a time and that the table must exist for the insert operation to succeed. | 
| Action on table | On the table defined, you can perform one of the following operations: 
 | 
| Schema and Edit schema | A schema is a row description. It defines the number of fields (columns) to be processed and passed on to the next component. When you create a Spark Job, avoid the reserved word line when naming the fields. Built-In: You create and store the schema locally for this component only. Repository: You have already created the schema and stored it in the Repository. You can reuse it in various projects and Job designs. When the schema to be reused has default values that are integers or functions, ensure that these default values are not enclosed within quotation marks. If they are, you must remove the quotation marks manually. For more information, see Retrieving table schemas. Click Edit schema to make changes to the schema. If the current schema is of the Repository type, three options are available: 
 | 
| File Name | Enter the name of the file to be generated and loaded. Information noteNote: This file can be on the same machine as the database server resides or on
                     another machine. If the file is on the same machine as the database server
                     resides, fill the path to the file in the form prompted in the field; if the
                     file is on another machine, fill the universal naming convention (UNC) name
                     (that is, \\{Servername}\{Sharename}\{Path}\{Filename})
                     of the file in this field. In the second case, you need to have the permission
                     to read and write the file. See Bulk importing to SQL Server from a remote
                        data file for related information. | 
| Append | Select this check box to add the new rows at the end of the records | 
Advanced settings
| Properties | Description | 
|---|---|
| Additional JDBC parameters | Specify additional connection properties for the database connection you are creating. The properties are separated by semicolon and each property is a key-value pair. For example, encrypt=true;trustServerCertificate=false; hostNameInCertificate=*.database.windows.net;loginTimeout=30; for Azure SQL database connection. This field is not available if the Use an existing connection check box is selected. | 
| Authenticate using Azure Active Directory | Select this option to use Azure Active Directory authentication when establishing the connection. See Azure AD Authentication for related information. This option is only available when Microsoft is selected from the JDBC Provider drop-down list in the Basic settings view. | 
| Enable always encrypted (Column encryption) | Select this option to use the Microsoft Always encrypted feature to encrypt and protect your
                  data. To use this option, you need to have previously stored your secrets with
                     Azure Key Vault: 
 Some limitations regarding query operations and statements apply to this feature. For the exhaustive list of limitations, see the Microsoft SQL Server documentation. | 
| Field separator | Character, string, or regular expression to separate fields. | 
| Row separator | String (ex: "\n"on Unix) to distinguish rows. | 
| First row | Type in the number of the row where the action should start. | 
| Include header | Select this check box to include the column header. | 
| Code page | OEM code pages used to map a specific set of characters to numerical code point values. | 
| Data file type | Select the type of data being handled. | 
| Encoding | Select the encoding from the list or select Custom and define it manually. This field is compulsory for DB data handling. | 
| tStatCatcher statistics | Select this check box to collect log data at the component level. | 
Usage
| Usage guidance | Description | 
|---|---|
| Usage rule | This component is mainly used when no particular transformation is required on the data to be loaded onto the database. | 
| Dynamic settings | Click the [+] button to add a row in the table and fill the Code field with a context variable to choose your database connection dynamically from multiple connections planned in your Job. This feature is useful when you need to access database tables having the same data structure but in different databases, especially when you are working in an environment where you cannot change your Job settings, for example, when your Job has to be deployed and executed independent of Talend Studio. The Dynamic settings table is available only when the Use an existing connection check box is selected in the Basic settings view. Once a dynamic parameter is defined, the Component List box in the Basic settings view becomes unusable. For examples on using dynamic parameters, see Reading data from databases through context-based dynamic connections and Reading data from different MySQL databases using dynamically loaded connection parameters. For more information on Dynamic settings and context variables, see Dynamic schema and Creating a context group and define context variables in it. | 
| Limitation | The database server must be installed on the same machine where Talend Studio is installed or where the Job using tMSSqlOutputBulkExec is deployed, so that the component functions properly. |