JDBC Driver connection parameter reference¶
This topic lists the connection parameters that you can use to configure the JDBC driver.
You can set these parameters in the JDBC connection string or in a Java Properties
object.
Required parameters¶
This section lists the parameters that you must set in the connection string or in the Map of properties.
Note
You must also set the parameters for authentication.
user¶
- Description:
Specifies the login name of the user for the connection.
Authentication parameters¶
allowUnderscoresInHost¶
- Description:
Specifies whether to allow underscores in account names. The JDBC Driver does not support underscores in URLs, which include the account name, so the JDBC Driver automatically converts underscores to hyphens. The default value is
false.Note
Beginning with version 3.13.25, the Snowflake JDBC driver changes the default value of the
allowUnderscoresInHostparameter tofalse. This change impacts PrivateLink customers whose account names contain underscores. In this situation, you must override the default value by settingallowUnderscoresInHosttotrue.
authenticator¶
- Description:
Specifies the authenticator to use for verifying user login credentials. You can set this to one of the following values:
snowflaketo use the internal Snowflake authenticator.
externalbrowserto use your web browser to authenticate with Okta, AD FS, or any other SAML 2.0-compliant identity provider (IdP) that has been defined for your account.
https://<okta_account_name>.okta.com(i.e. the URL endpoint for your Okta account) to authenticate through native Okta (only supported if your IdP is Okta).
oauthto authenticate using OAuth. When OAuth is specified as the authenticator, you must also set thetokenparameter to specify the OAuth token (see below).
snowflake_jwtto authenticate using key pair authentication. For more details about key pair authentication, see Using key pair authentication and key rotation.
username_password_mfato authenticate with MFA token caching. For more details, see Using multi-factor authentication
oauth_authorization_codeManually authenticate using an OAuth authorization code with your web browser and a chosen identity provider (including Snowflake as an IdP). For more information, see Using the OAuth 2.0 Authorization Code flow.
oauth_client_credentialsAutomatically authenticate using OAuth client credentials with your chosen identity provider (Snowflake as an IdP doesn’t support the client credentials flow). For more information, see Using the OAuth 2.0 Client Credentials flow.
programmatic_access_tokento authenticate with a programmatic access token (PAT). For more information, see Authenticating with a programmatic access token (PAT).
WORKLOAD_IDENTITYto authenticate with the workload identity federation (WIF) authenticator.If the connection string specifies a key pair, then key pair authentication will be used even if the
authenticatorparameter is unset or is set to ‘snowflake’.For more information on authentication, see Managing/Using federated authentication and Clients, drivers, and connectors.
- Default:
snowflake
disableGcsDefaultCredentials¶
- Description:
Specifies whether use the default credential lookup instead of external application default credentials when using GCP (Google Cloud Platform).
By default, GCP users can use a variety of options to set up Google Application Default Credentials outside of Snowflake. Occasionally, these authentication methods can interfere with cloud storage operations that originate from the Snowflake JDBC driver. In such cases, you can set the value to
trueto force the driver to ignore GCP credentials from other sources.You can also use the
net.snowflake.jdbc.disableGcsDefaultCredentialsJava property to achieve the same effect.- Default:
true
disableSamlURLCheck¶
- Description:
Specifies whether to disable the validation check of a SAML response.
- Default:
false
passcode¶
- Description:
Specifies the passcode to use for multi-factor authentication.
For more information about multi-factor authentication, see Multi-factor authentication (MFA).
passcodeInPassword¶
- Description:
Specifies whether the passcode for multi-factor authentication is appended to the password:
on(ortrue) specifies the passcode is appended.
off(orfalse) or any other value specifies the passcode is not appended.- Default:
off
password¶
- Description:
Specifies the password for the specified user.
There are two ways to specify the password:
The first way is to pass the user ID and password directly to the
getConnectionmethod:String user = "<user>"; // replace "<user>" with your user name String password = "<password>"; // replace "<password>" with your password Connection con = DriverManager.getConnection("jdbc:snowflake://<account>.snowflakecomputing.cn/", user, password);
The second way is to create a
Propertiesobject, update the object with the password, and pass the object to thegetConnectionmethod:String user = "<user>"; // replace "<user>" with your user name String password = "<password>"; // replace "<password>" with your password Properties props = new Properties(); props.put("user", user); props.put("password", password); Connection con = DriverManager.getConnection("jdbc:snowflake://<account>.snowflakecomputing.cn/", props);Attention
We strongly recommend that you do not include the user password directly in the JDBC connection string because the password could be inadvertently exposed by the client application that uses the string to connect to Snowflake. Instead, use the interface(s) provided by the application to specify the user password.
privatekey¶
- Description:
Specifies the private key for the specified user. See Using key pair authentication and key rotation.
private_key_base64¶
- Description:
Specifies the base64 encoded private key for the specified user. See Using key pair authentication and key rotation.
private_key_file¶
- Description:
Specifies the path to the private key file for the specified user. See Using key pair authentication and key rotation.
private_key_file_pwd¶
- Description:
(Deprecated) Use private_key_pwd instead.
private_key_pwd¶
- Description:
Specifies the passphrase to decrypt the private key file or base64 encoded private key for the specified user. See Using key pair authentication and key rotation.
token¶
- Description:
Specifies the OAuth token to use for authentication, where
<string>is the token. This parameter is required only when setting the authenticator parameter tooauth, except as noted below.Note
Beginning with version 3.13.24, the Snowflake JDBC Driver lets you send the OAuth token in the connection password in addition to including it in the
tokenconfiguration parameter. If thetokenconfiguration parameter is not specified, theDriver.connect()method expects the token to be stored in the connection password.This feature primarily supports using OAuth authentication for connection pools, allowing you to pass refreshed tokens as needed instead of being restricted by an expired token specified in the
tokenconfiguration parameter.For example, instead of setting he
tokenconfiguration parameter, you can pass the token as the password in thegetConnection()method properties, similar to the following:Properties props = new Properties(); props.put("user", "myusername"); props.put("authenticator", "oauth"); props.put("role", "myrole"); props.put("password", "xxxxxxxxxxxxx"); // where xxxxxxxxxxxxx is the token string Connection myconnection = DriverManager.getConnection(url, props);- Default:
None
oauthClientId¶
- Description:
Value of
client idprovided by the identity provider for Snowflake integration (Snowflake security integration metadata).
oauthClientSecret¶
- Description:
Value of the
client secretprovided by the identity provider for Snowflake integration (Snowflake security integration metadata).
oauthTokenRequestUrl¶
- Description:
Identity Provider endpoint supplying the access tokens to the driver. When using Snowflake as an Identity Provider, this value is derived from the
serveroraccountparameters.
oauthScope¶
- Description:
Scope requested in the Identity Provider authorization request. By default, it is derived from the role. When multiple scopes are required, the value should be a space-separated list of multiple scopes.
oauthRedirectUri¶
- Description:
URI to use for authorization code redirection (Snowflake security integration metadata). Default:
http://127.0.0.1:{randomAvailablePort}.
workloadIdentityProvider¶
- Description:
Platform of the workflow identity provider. Possible values include:
AWS,AZURE,GCP, andOIDC.
Parameters for the default database, role, schema, and warehouse¶
db¶
- Description:
Specifies the default database to use once connected, or specifies an empty string. The specified database should be an existing database for which the specified default role has privileges.
If you need to use a different database after connecting, execute the USE DATABASE command.
role¶
- Description:
Specifies the default access control role to use in the Snowflake session initiated by the driver. The specified role should be an existing role that has already been assigned to the specified user for the driver. If the specified role has not already been assigned to the user, the role is not used when the session is initiated by the driver.
If you need to use a different role after connecting, execute the USE ROLE command.
For more information about roles and access control, see Overview of Access Control.
schema¶
- Description:
Specifies the default schema to use for the specified database once connected, or specifies an empty string. The specified schema should be an existing schema for which the specified default role has privileges.
If you need to use a different schema after connecting, execute the USE SCHEMA command.
warehouse¶
- Description:
Specifies the virtual warehouse to use once connected, or specifies an empty string. The specified warehouse should be an existing warehouse for which the specified default role has privileges.
If you need to use a different warehouse after connecting, execute the USE WAREHOUSE command can be executed to set a different warehouse for the session.
Proxy parameters¶
disableSocksProxy¶
- Description:
Specifies whether the driver should ignore the SOCKS proxy configuration specified in the Java system options:
on(ortrue) specifies to ignore the proxy.
off(orfalse) or any other value specifies to use the proxy.Note
Setting this connection parameter alters the behavior for all connections on the same JVM (Java virtual machine).
- Default:
off
nonProxyHosts¶
- Description:
Specifies the lists of hosts that the driver should connect to directly, bypassing the proxy server. See Specifying a proxy server in the JDBC connection string for details.
proxyHost¶
- Description:
Specifies the hostname of the proxy server to use. See Specifying a proxy server in the JDBC connection string for details.
proxyPassword¶
- Description:
Specifies the password for authenticating to the proxy server. See Specifying a proxy server in the JDBC connection string for details.
proxyPort¶
- Description:
Specifies the port number of the proxy server to use. See Specifying a proxy server in the JDBC connection string for details.
proxyProtocol¶
- Description:
Specifies the protocol used to connect to the proxy server. See Specifying a proxy server in the JDBC connection string for details.
- Default:
http
proxyUser¶
- Description:
Specifies the user name for authenticating to the proxy server. See Specifying a proxy server in the JDBC connection string for details.
useProxy¶
- Description:
Specifies whether the driver should use a proxy:
on(ortrue) specifies that the driver should use a proxy.
off(orfalse) or any other value specifies that the driver should not use a proxy. This setting has no effect if JVM proxy arguments are present.See Specifying a proxy server in the JDBC connection string.
- Default:
off
Timeout parameters¶
loginTimeout¶
- Description:
Specifies the number of seconds to wait for a response when connecting to the Snowflake service before returning a login failure error.
- Default:
60
networkTimeout¶
- Description:
Specifies the number of milliseconds to wait for a response when interacting with the Snowflake service before returning an error.
0(zero) specifies that no network timeout is set.- Default:
0
net.snowflake.jdbc.http_client_connection_timeout_in_ms¶
- Description:
Specifies the maximum time, in milliseconds, to wait on fully establishing a new connection (including TLS negotiation) with the remote host.
You can also set this in the connection string with
${HTTP_CLIENT_CONNECTION_TIMEOUT}.
- Default:
60000(1 minute)
net.snowflake.jdbc.http_client_socket_timeout_in_ms¶
- Description:
Specifies the maximum time, in milliseconds, to wait for data (time of inactivity between two data packets) after a connection is successfully established.
You can also set this in the connection string with
${HTTP_CLIENT_SOCKET_TIMEOUT}.
- Default:
300000(5 minutes)
queryTimeout¶
- Description:
Specifies the number of seconds to wait for a query to complete before returning an error.
0(zero) specifies that the driver should wait indefinitely.- Default:
0
Certificate revocation list (CRL) options¶
These options are available in driver versions 3.27.0 and later.
CERT_REVOCATION_CHECK_MODE¶
- Description:
How to treat certificate revocation. Note that certificate revocation checks with CRLs are resource-heavy tasks, both for memory and CPU. The following values are supported:
ENABLED: Enables CRLs. Connections are terminated if there are errors related to obtaining and parsing the CRL.
ADVISORY: Enables CRLs. Errors are logged but do not block the connection; revocation status is not enforced.
DISABLED: Disables CRLs. Certificates can only be revoked manually.- Default:
DISABLED
ALLOW_CERTIFICATES_WITHOUT_CRL_URL¶
- Description:
Whether certificates without an associated CRL are accepted. If false, certificates lacking a CRL distribution point cause the connection to fail. Applies only when
CERT_REVOCATION_CHECK_MODEis notDISABLED.- Default:
false
ENABLE_CRL_IN_MEMORY_CACHING¶
- Description:
Whether to enable in-memory caching of CRLs. If enabled, the driver caches CRLs in memory to improve performance. Applies only when
CERT_REVOCATION_CHECK_MODEis notDISABLED.- Default:
true
ENABLE_CRL_DISK_CACHING¶
- Description:
Whether to enable disk caching of CRLs. If enabled, the driver caches CRLs on disk to improve performance. Applies only when
CERT_REVOCATION_CHECK_MODEis notDISABLED.- Default:
true
CRL_CACHE_VALIDITY_TIME¶
- Description:
Specifies the time, in seconds, that a CRL is considered valid. After this time, the CRL is refreshed from the source.
- Default:
86400(1 day)
CRL_RESPONSE_CACHE_DIR¶
- Description:
Specifies the directory where the CRL response cache is stored.
- Default:
Windows:
%USERPROFILE%AppDataLocalSnowflakeCachescrls
Linux:
$HOME/.cache/snowflake/crls
macOS:
$HOME/Library/Caches/Snowflake/crls
CRL_ON_DISK_CACHE_REMOVAL_DELAY¶
- Description:
Specifies the time, in seconds, to delay removing the on-disk cache.
- Default:
604800(1 week)
Other parameters¶
application¶
- Description:
Snowflake partner use only: Specifies the name of a partner application to connect through JDBC.
CLEAR_BATCH_ONLY_AFTER_SUCCESSFUL_EXECUTION¶
- Description:
Specifies whether to clear batch entries only when a batch updates successfully.
true: Batch entries are cleared only when the batch updated successfully.
false: TheStatement.executeBatchandStatement.executeLargeBatchnever clears batch entries after execution, whilePreparedStatement.executeBatchandPreparedStatement.executeLargeBatchalways clears batch entries after execution.This parameter is available for backward compatibility.
- Default:
false
client_config_file¶
- Description:
Specifies the path of a logging configuration file that you can use to define the logging level and directory for saving log files. .. :Default:
sf_client_config.json
CLIENT_TELEMETRY_ENABLED¶
- Description:
Specifies whether to send in-band telemetry data to Snowflake.
- Default:
true.
CLIENT_TREAT_TIME_AS_WALL_CLOCK_TIME¶
- Description:
Specifies whether time values should be processed as literal wall-clock times, thereby avoiding potential discrepancies caused by timezone-sensitive epoch conversions when the parameter is
false.: Default:
false.
DIAGNOSTICS_ALLOWLIST_FILE¶
- Description:
Full path and filename of the JSON file containing the output of the SYSTEM$ALLOWLIST or SYSTEM$ALLOWLIST_PRIVATELINK functions.
If
ENABLE_DIAGNOSTICSistrue, you must provide this parameter.
disableOCSPChecks¶
- Description:
When
true, driver does not perform any OCSP checks- Default:
false
ENABLE_DIAGNOSTICS¶
- Description:
When
trueand the calling application invokes theDriverManagerorDataSourcegetConnection()method, the driver runs several connectivity tests and writes the results in a pre-configured log file. The driver also returns the following exception:net.snowflake.client.jdbc.SnowflakeSQLException: A connection was not created because the driver is running in diagnostics mode. If this is unintended then disable diagnostics check by removing the ENABLE_DIAGNOSTICS connection parameterIf you enable this parameter, you must provide a value for the
DIAGNOSTICS_ALLOWLIST_FILEparameter.- Default:
false
ENABLE_EXACT_SCHEMA_SEARCH_ENABLED¶
- Description:
Enables or disables exact schema searches in some
DatabaseMetaDatamethods.- Default:
false(for backward compatibility)
enablePatternSearch¶
- Description:
Enables or disables pattern search for
getCrossReference,getExportedKeys,getImportedKeys, andgetPrimaryKeysmetadata operations that should not use their parameters as patterns.- Default:
true
ENABLE_WILDCARDS_IN_SHOW_METADATA_COMMANDS¶
- Description:
Enables or disables treating wildcards as literals in some
DatabaseMetaDatamethods when creating SQL queries. This setting can be useful when a client is not able to escape wildcards in identifiers.- Default:
true
enablePutGet¶
- Description:
Specifies whether to allow PUT and GET commands access to local file systems. Setting the value to
falsedisables PUT and GET command execution.- Default:
true
IMPLICIT_SERVER_SIDE_QUERY_TIMEOUT¶
- Description:
Specifies whether to send a timeout in the query sent to Snowflake.
true: CallingStatement.setQueryTimeoutsets the timeout on the query sent to Snowflake in addition to the client-side timeout.
false: CallingStatement.setQueryTimeoutsets only client side timeout is set.- Default:
false
insecureMode¶
- Description:
Deprecated. See disableOCSPChecks.
JAVA_LOGGING_CONSOLE_STD_OUT¶
- Description:
Specifies whether to write log message to standard output instead of standard error.
- Default:
false
JAVA_LOGGING_CONSOLE_STD_OUT_THRESHOLD¶
- Description:
Specifies the maximum log message level to write to standard output. Higher log levels are written to standard error. Valid only when
JAVA_LOGGING_CONSOLE_STD_OUTistrue. Possible values include:
OFF
SEVERE
WARNING
INFO
CONFIG
FINE
FINER
FINEST
ALL- Default:
none, which is equivalent to setting the value to
OFForSEVERE.
JDBC_ARROW_TREAT_DECIMAL_AS_INT¶
- Description:
Specifies whether to return all numbers in an arrow result set from a
getObjectcall as integers. If this value and the JDBC_TREAT_DECIMAL_AS_INT parameter values are bothfalse, all integer numbers in arrow return sets from agetObjectcall are returned as aBigDecimaltype.- Default:
true
JDBC_DEFAULT_FORMAT_DATE_WITH_TIMEZONE¶
- Description:
Specifies whether to use the previously hardcoded value for the formatter (for backwards compatibility).
- Default:
true
JDBC_GET_DATE_USE_NULL_TIMEZONE¶
- Description:
Specifies whether to use the previously null timezone value for the
getDatemethod (for backwards compatibility).- Default:
true
maxHttpRetries¶
- Description:
Specifies the maximum number of times to retry failed HTTP requests before returning an error.
- Default:
7
net.snowflake.jdbc.max_connections¶
- Description:
Specifies the total maximum connections available in the connection pool.
- Default:
300
net.snowflake.jdbc.max_connections_per_route¶
- Description:
Specifies the maximum number of connections allowed for a single port or URL. The value cannot exceed the net.snowflake.jdbc.max_connections value.
- Default:
300
net.snowflake.jdbc.objectMapper.maxJsonStringLength¶
- Description:
Specifies the maximum number of bytes for a string. You can increase the value for this Java property to set a larger buffer for Snowflake response deserialization if you receive error messages similar to the following:
com.fasterxml.jackson.core.exc.StreamConstraintsException: String length (XXXXXXX) exceeds the maximum length (180000000)- Default:
180000000
ocspFailOpen¶
- Description:
Specifies that the driver should “fail open” if unable reach the OCSP server to verify the certificate. See OCSP.
OWNER_ONLY_STAGE_FILE_PERMISSIONS_ENABLED¶
- Description:
Sets owner-only permissions (0600) on the directory created for stage files.
- Default:
false
putGetMaxRetries¶
- Description:
Specifies the maximum number of times to retry PUT/GET exceptions for storage clients.
- Default:
25
stringsQuotedForColumnDef¶
- Description:
If this parameter is set to
true, then whenDatabaseMetaData.getColumns()andDatabaseMetaData.getProcedureColumns()return a value of typeStringin the COLUMN_DEF column, that value is embedded in single quotes. (If the data type of the value is notString, then the value is not quoted, regardless of the setting of this parameter.)
truespecifies that string values should be embedded in single quotes (the quotes are part of the string, not delimiters). This complies with the JDBC standard.
falsespecifies that string values are not embedded in single quotes.- Default:
false
MAX_TLS_VERSION¶
- Description:
Specifies the maximum SSL/TLS version to use when initiating a TLS handshake. Valid values include:
TLSv1.2
TLSv1.3Snowflake recommends leaving this setting at its default when you don’t have a specific need to change it.
- Default:
TLSv1.3
MIN_TLS_VERSION¶
- Description:
Specifies the minimum SSL/TLS version to use when initiating a TLS handshake. Valid values include:
TLSv1.2
TLSv1.3Snowflake recommends leaving this setting at its default when you don’t have a specific need to change it.
- Default:
TLSv1.2
tracing¶
- Description:
Specifies the log level for the driver. The driver uses the standard Java log utility. You can set this parameter to one of the following log levels:
OFF
SEVERE
WARNING
INFO
CONFIG
FINE
FINER
FINEST
ALL- Default:
INFO