JDBC Driver 3.8.4
- | SNOW-38957 | Connection errors will return multiple error codes instead of 200002
- | SNOW-70888 | Update Client Driver OCSP Endpoint URL for Private Link Customers
- | SNOW-19476 | Implement DatabaseMetadata.getTablePrivileges
- | SNOW-80773 | Connection.setClientInfo refuses any parameter
- | SNOW-81015 | proxyUser and proxyPassword are optional in the JDBC connect string.
- | SNOW-81829 | Use Standard Connection Fields for Global URL
- | SNOW-78996 | Remove https from account name if specified.
- | SNOW-74255 | Implement java.sql.Statement.executeLargeBatch
JDBC Driver 3.8.3
- | SNOW-70888 | JDBC OCSP URL Update for Privatelink
JDBC Driver 3.8.2
- | SNOW-62766 | Deprecate CLIENT_RESULT_PREFETCH_THREADS and CLIENT_RESULT_PREFETCH_SLOTS
- | SNOW-77592 | Implemented getProcedures and getProcedureColumns
- | SNOW-79011 | JDBC don't surface errors when the session is gone
- | SNOW-79125 | Key comparison should be done by equals method instead of double equal signs
- | SNOW-79699 | Upgrade com.fasterxml.jackson.core:jackson-databind to version 2.9.9 or later
- | SNOW-80208 | Fixed a missing data bug on JDBC 3.7.1+’s resultChunkV2: strictly clean isNulls while using from the cache
JDBC Driver 3.8.1
- |SNOW-76035 | DML returns the number of updated rows in getUpdateCount() otherwise -1
- |SNOW-70751 | Connection.setClientInfo for JDBC to support ApplicationName
- |SNOW-74086 | Implement DatabaseMetaData.getFunctionColumns
- |SNOW-76375 | Implement PreparedStatement.getParameterMetaData(), ParameterMetaData.getParameterCount() ParameterMetaData.getParameterType(int)
- |SNOW-77987 | Revoked OCSP Response persists in in-memory cache
- |SNOW-67078 | executeBatch supports PUT and GET
- |SNOW-79011 | Ignore session is missing error when closing connection
JDBC Driver 3.8.0
- |SNOW-75285|Remove sensitive data from URL for JDBC logging
- |SNOW-75925|Create JDBC interfaces SnowflakeStatement, SnowflakeResultSet, and, SnowflakePreparedStatement to expose Snowflake specific APIs: SnowflakeStatement.getQueryID(), SnowflakeStatement.getBatchQueryID(), SnowflakeResultSet.getQueryID(), SnowflakePreparedStatement.getQueryID()
- |SNOW-76010|Updated c3p0 version for tests
- |SNOW-76375|Implements DataBaseMetaData.getParameterMetaData() and ParameterMetaData.getType()
- |SNOW-75285|Scrub secrets before logging
- |SNOW-77160|Add OCSP_MODE metric
- |SNOW-74086|Add getFunctionColumns
- |SNOW-76150|OCSP SoftFail support for JDBC
JDBC Driver 3.7.2
- |SNOW-67615| Apply CLIENT_METADATA_REQUEST_USE_CONNECTION_CTX behavior to all JDBC get functions with catalog and schema as inputs
- |SNOW-68058| CLIENT_SESSION_KEEP_ALIVE_HEARTBEAT_FREQUENCY for JDBC
- |SNOW-73034| Setting the index 0 for binding is ignored. It should raise an exception.
- |SNOW-68756| JAVA heap space error when querying data: provide detailed error message and suggestions when hits OOM
- |SNOW-70356| Ensure all associated objects are freed when closed.
- |SNOW-70409| Close all associated objects when the parent object is closed.
- |SNOW-71689| Update Client Driver to use new OCSP Endpoint URL based on Client Failover
- |SNOW-73555| Fixed Not dropping unselected columns after creating temp table
- |SNOW-67871| Add getQueryId() method to SnowflakeStatementV1 and SnowflakeResultSetV1
- |SNOW-74238| JDBC SnowflakeBasicDatasource use a driver does not comes from Snowflake
JDBC Driver 3.7.1
- | SNOW-73421 | Internal change for future improvement
- |SNOW-70354 | Throw SQLException when calling methods of the closed objects.
JDBC Driver 3.7.0
- |SNOW-65887|Change source and target Java version to 1.8 for JDBC driver
JDBC Driver 3.6.28
- |SNOW-67095|Fix a bug which caused the 3.6.x JDBC Driver hangs when resultSet is not consumed. The JDBC driver now always releases resultSet and its memory usage when a statement is closed.
- |SNOW-67120|Change getTableTypes() from only returning TABLE and VIEW to including TEMPORARY and TRANSIENT types.
- |SNOW-66302|Fixed parsing date and time format issue.
JDBC Driver 3.6.27
- |SNOW-42661| Add unknown type binding variable support in table UDF
- |SNOW-66840| Align CLIENT_METADATA_REQUEST_USE_CONNECTION_CTX behavior of JDBC with ODBC
- |SNOW-67327| NPE when timestamp value is null in binding
- |SNOW-62511| Mask AWS password in a query
JDBC Driver 3.6.26
- |SNOW-66026|Change all INFO and WARNING logging to DEBUG in JDBC
- |SNOW-66015|Binary column always returns 0 precision
- |SNOW-65421|Fixed binding null with data type raising error.
- |SNOW-65154|Fixed CHANGELOG.rst format
- |SNOW-64977|More granular error message for failed batch loads
- |SNOW-64063|Update JDBC Loader API to using CREATE TABLE ... LIKE syntax
- |SNOW-53174|Improve error messages when a driver fails to connect to Snowflake, S3 or OCSP
JDBC Driver 3.6.25
- |SNOW-64564| Lazy init JDBC legacy logger
- |SNOW-63813| Explicitly allows all proxy data to be fed via the JDBC connection string
- |SNOW-64570| Failed to serialize ClientAuthnDTO in boomi cloud environment
JDBC Driver 3.6.24
- |SNOW-63844| Security vulnerability: com.fasterxml.jackson.core:jackson-databind >= 2.9.0, < 2.9.8
- |SNOW-62247| Add enum REJECTED_RECORD in class LoadingError
- |SNOW-61650| Support Dell boomi cloud
JDBC Driver 3.6.23
- |SNOW-63523| Removed hard-coded
Level.ALL
for logger initialization. - |SNOW-63481| Security enhancement: Updated
tika-core
to 1.20. - |SNOW-63341| Driver no longer throws an incident for a
no row found
user error. - |SNOW-63240| Added additional null checks in statements.
- |SNOW-63137| Changed default driver log level from
ALL
toINFO
in thelogging.properties
example (in the Snowflake documentation). - |SNOW-63067| Fixed issue with intermittent error in driver even though the Query Details page (in the web interface) shows the query was successful.
- |SNOW-61210| Improved OCSP Cert Auth and Handshake retry.
- |SNOW-45402| Added support for 256-bit encryption for Azure stages.
JDBC Driver 3.6.22
- |SNOW-63026| Driver now invalidates outdated OCSP responses when checking the cache.
- |SNOW-62996| Fixed intermittent JDBC connection failure in PrivateLink.
- |SNOW-62140| The default setting for CLIENT_MEMORY_LIMIT parameter is now dynamic, based on the amount of system memory available.
- |SNOW-61424| Removed unnecessary/redundant version logs.
- |SNOW-54606| Fixed issue that caused the following exception when using the driver with Java Spring Boot:
Caused by: java.lang.IllegalArgumentException: URL must start with 'jdbc'
. - |SNOW-63163| Fixed NPE when fetching data.
JDBC Driver 3.6.21
- |SNOW-61862| Driver now uses
YYYY-MM-DD HH24:MI:SS.FF9 TZH:TZM
for timestamp array binding.
JDBC Driver 3.6.20
- |SNOW-61209| Fixed performance issue with result set download.
JDBC Driver 3.6.19
- |SNOW-44393| Driver now catches exceptions for
prepareStatement
so that execution can continue.
JDBC Driver 3.6.17
- |SNOW-59862| Added JVM properties for CLIENT_PREFETCH_THREADS, CLIENT_MEMORY_LIMIT, and CLIENT_RESULT_CHUNK_SIZE.
- |SNOW-58812| Fixed issue with PARALLEL parameter for PUT and GET commands.
- |SNOW-59802| Fixed issue with wrong TIME format for the Loader API.
- |SNOW-56081| CLOB data type now mapped to STRING data type in Snowflake.
JDBC Driver 3.6.16
- |SNOW-57107| Driver now checks to ensure all dependencies are correctly shaded.
- |SNOW-56603| As announced previously, the CLIENT_MEMORY_LIMIT parameter now governs the total memory used per process instead of per query.
JDBC Driver 3.6.15
- |SNOW-56771| Implemented shading of additional dependencies to a new location to mitigate package conflicts.
- |SNOW-57051| Fixed CVE-2018-11761.
- |SNOW-56836| Added support for nanoseconds precision for TIMESTAMP data in Loader API.
- |SNOW-56604| Added
skipParsing
option toprepareStatement
method to skip fetching metadata.
JDBC Driver 3.6.14
- |SNOW-55075| Introduced the CLIENT_RESULT_COLUMN_CASE_INSENSITIVE session parameter to enable matching case-sensitivity for column names in
ResultSet
.
JDBC Driver 3.6.13
- |SNOW-55868| Added service name support for multi-GS clustering (internal feature).
- |SNOW-55138| Upgraded dependency to fix known vulnerabilities.
- |SNOW-55095| Internal change for pending feature.
- |SNOW-54926| Added
compressFileByPut
,compressDataBeforePut
,compressLevel
to Loader API. - |SNOW-55035| Added
request_guid
for HTTP request tracing.
JDBC Driver 3.6.12
- |SNOW-26324| Added
--version
option to return the JDBC driver version and additional information.
JDBC Driver 3.6.11
- |SNOW-53650| Internal change for pending feature.
- |SNOW-53452| Internal change for pending feature.
JDBC Driver 3.6.10
- |SNOW-52486| Fixed
clientStartTime
andretryCount
metrics inquery-request
. - |SNOW-50766| Updated driver to enforce virtual host style for S3 URLs.
- |SNOW-50717| Fixed
SQLException
ingetFunctionColumns
API call. - |SNOW-45419| Changed the heartbeat frequency to hourly to mitigate issue with token expiration.
- |SNOW-39748| Disabled cookie management.
JDBC Driver 3.6.9
- |SNOW-51691| Added support for specifying file cache directories as environment variables or JVM system properties.
- |SNOW-49850| Added support for disabling SOCKS proxy for JDBC traffic using a new connection parameter (
disableSocksProxy
). - |SNOW-41673| Added
retryCount
andclientStartTime
parameters toquery-request
requests for JDBC.
JDBC Driver 3.6.8
- |SNOW-49653| Internal change for pending feature.
JDBC Driver 3.6.7
- |SNOW-50141| Fixed issue with
setObject
not handling BOOLEAN data type. - |SNOW-49982| Added
onError
parameter in the Loader API; corresponds to theON_ERROR
option in the COPY INTO <table> command. - |SNOW-49850| Upgraded AWS SDK to enable support for disabling socket proxy.
- |SNOW-49653| Internal change for pending feature.
JDBC Driver 3.6.6
- |SNOW-50032| Fixed issue with the OCSP retry check, which wasn't performed if the validity check failed.
JDBC Driver 3.6.5
- |SNOW-45631| Improved array binding when routing bind values through stage.
- |SNOW-45545| Fixed issue with the data-to-CSV converter for the Loader API.
NULL
and empty values are now correctly converted toNULL
and empty, respectively. - |SNOW-45021| Removed login name requirement when authenticating with an OAuth access token.
JDBC Driver 3.6.4
- |SNOW-45612| Added
authenticator
setting toSnowflakeBasicDatasource
. - |SNOW-45600| Driver now closes the HTTP response stream to allow HTTP client to reuse socket.
- |SNOW-45484| Fixed calculation for 50MB file size.
- |SNOW-41096| Added a parameter to control Telemetry service (for pending feature in the Spark Connector).
JDBC Driver 3.6.3
- |SNOW-43251| Fixed erroneous exception raised when COPY statement loads 0 files.
JDBC Driver 3.6.2
- |SNOW-44536| Fixed the Loader API to support CSV filenames that contain spaces.
- |SNOW-44497| Fixed the Loader API to suppress race conditions for date formatting.
- |SNOW-44405| Added
copyEmptyFieldAsEmpty
to the Loader API to supportEMPTY_FIELD_AS_NULL=false
option for COPY command.
JDBC Driver 3.6.1
- |SNOW-43215| Updated the driver to support OCSP dynamic cache server for PrivateLink.
JDBC Driver 3.6.0
- |SNOW-42908| Enabled the automatic class loader for
SnowflakeDriver
class. - |SNOW-39684| Enabled the OCSP Response Cache Server by default.
JDBC Driver 3.5.5
- |SNOW-42722| Added support for SF_OCSP_RESPONSE_CACHE_DIR environment variable to specify the OCSP cache file location.
- |SNOW-39872| Added APPLICATION connection property to allow setting the name for 3rd-party applications.
JDBC Driver 3.5.4
- |SNOW-41484| Fixed URL mismatch error that occurred when using OKTA authentication and the JDBC connection URL contains a port number.
JDBC Driver 3.5.3
- |SNOW-40230| Removed dependency on
commons-lang3
package. - |SNOW-34464| Added support for key pair authentication.
JDBC Driver 3.5.2
- |SNOW-38455| Upgraded HttpClient to 4.5.5.
- |SNOW-38454| Upgraded Jackson JSON packages to 2.9.4.
JDBC Driver 3.5.1
- |N/A| Private release (for internal purposes only; no changes)
JDBC Driver 3.5.0
- |SNOW-38486| Added support for checking for OCSP revocation.
- |SNOW-37766| Added support for getting
SecureRandom
instances without specifying a provider name; this is required because the driver could be running under the IBM JDK.
JDBC Driver 3.4.3
- |SNOW-34464| Internal change for pending feature.
JDBC Driver 3.4.2
- |SNOW-37755| Refactored a server-side fix (SNOW-36580) on the client side.
- |SNOW-37184| Added support for binding object identifiers.
JDBC Driver 3.4.1
- |SNOW-37400| Added shaded
amazon.ion
package.
JDBC Driver 3.4.0
- |SNOW-37276| Fixed an issue where the driver could not use the TLS 1.2 cipher suites in JDK1.7.
- |SNOW-37242| Allow preparing all types of statements (reverts a change introduced in v3.3.0).
- |SNOW-37186| Fixed an issue with the NUMBER format in JDBC
SnowflakeBasicaDataSource.java
.
JDBC Driver 3.3.3
- |SNOW-36917| Fixed an issue where the Loader API incorrectly converted timestamp dates earlier than 1582-Oct-04 due to differences between the Julian and Gregorian calendar.
- |SNOW-35613| Internal change for pending feature.
JDBC Driver 3.3.2
- |SNOW-32282| Internal change for pending feature.
- |SNOW-32001| Replaced AWS_ID and AWS_KEY with newer versions.
JDBC Driver 3.3.1
- |SNOW-30511| Fixed issue where Okta returned a 403 error (during federated authentication) due to the driver caching the Okta token in a cookie.
JDBC Driver 3.3.0
- |SNOW-32656| Driver behavior changed to throw an exception if SQL statement cannot be prepared.
JDBC Driver 3.2.7
- |SNOW-32618| Added support for SAML 2.0-compliant services/applications for federated authentication by adding the
externalbrowser
option to theauthenticator
connection parameter.
JDBC Driver 3.2.6
- |SNOW-31633| Changed
SFTimestamp
to accommodate the full range of timestamps supported in Snowflake.
JDBC Driver 3.2.5
- |SNOW-33566| Added support for
ResultSet.isLast()
,isBeforeFirsrt()
, andisAfterLast()
. - |SNOW-30962| Optimized the driver by combining
describe
andexecute
methods when there is no bind.
JDBC Driver 3.2.4
- |SNOW-33371| Fixed issue with v3.2.2 of the JDBC driver not working with the internal stage transfer feature for the Spark Connector.
- |SNOW-33227| Added support for new session parameter, JDBC_TREAT_DECIMAL_AS_INT, which, if set to TRUE (default value) instructs the driver to treat a column whose scale is zero as BIGINT instead of DECIMAL.
- |SNOW-33042| Added support to driver for PUT/GET over encrypted staged files for MS Azure.
JDBC Driver 3.2.3
- |SNOW-32618| JDBC driver ADFS integration rewritten using socket API.
JDBC Driver 3.2.2
- |SNOW-32618| Added support for SAML 2.0-compliant applications.
- |SNOW-31703| Added support for MS Azure.
JDBC Driver 3.2.1
- |SNOW-32060| Added support in the Loader API for binding
java.sql.Time
with the TIME data type and dropped support for bindingjava.sql.Time
with TIMESTAMP.
JDBC Driver 3.2.0
- |SNOW-31749| Updated the driver to use AWS SDK 1.11.165.
- |SNOW-31647| Fixed issue with NUMBER columns that have a scale of 0; they now return BIGINT instead of DECIMAL in the column metadata.
- |SNOW-30967| Updated the driver to use the latest S3 SDK to provide support for
proxy
andnonProxy
JVM options.
JDBC Driver 3.1.1
- |SNOW-31425| Fixed an issue with a missing statement type for
executeUpdate()
, which caused the statement to fail in USE commands.
JDBC Driver 3.1.0
- |SNOW-31069| Added support for enforcing JDBC driver to use TLS v1.2.
- |SNOW-30962| Added support for
executeBatch()
on prepared DML statements.
JDBC Driver 3.0.21
- |SNOW-15992| Support added for bulk updates using the APIs
Statement.addBatch()
,executeBatch()
, andclearBatch()
.
JDBC Driver 3.0.20
- |SNOW-30700| Driver now always uses Gregorian Calendar for DATE, TIME, and TIMESTAMP values in Loader API.
- |SNOW-18939| Added support for ORC file format in PUT command.
JDBC Driver 3.0.19
- |SNOW-29998| Implemented the basic
DataSource
API, which produces a standardConnection
object. - |SNOW-21314| Fixed Date value and validity for '0001-01-01'. Previously, it displayed incorrect date output.
JDBC Driver 3.0.18
- |SNOW-30146| Shortened the heartbeat interval to resolve some token expiration issues.
JDBC Driver 3.0.17
- |SNOW-28390| Fixed an issue where JDBC fails to parse an infinite number.
- |SNOW-26354| Driver returns a
SQLWarning
if a non-existent database or schema is specified in the connection properties.
JDBC Driver 3.0.16
- |SNOW-29262| Fixed an issue when calculating time spent on retry.
JDBC Driver 3.0.15
- |SNOW-29141| Fixed a null pointer exception when binding a null value in JDBC.
JDBC Driver 3.0.14
- |SNOW-28882| Fixed issue where null values were returned for 0 values cast to DOUBLE due to the
wasNull
flag not being set correctly. - |SNOW-28879| Fixed issue where the result chunk downloader thread prevented the JVM from exiting.
JDBC Driver 3.0.13
- |SNOW-24601| Implemented security patch for federated authentication in JDBC.
- |SNOW-24184| Open-sourced JDBC Driver on Github.
JDBC Driver 3.0.12
- |SNOW-25540| Added support for binding timestamp variables as timestamp_ntz for applications that use the bind API to load data into datetime columns (which are equivalent to the timestamp_ntz data type).
JDBC Driver 3.0.11
- |SNOW-27255| Fixed internal issue that occurred intermittently if the EventHandler encountered multiple class loaders.
JDBC Driver 3.0.10
- |SNOW-27320| Reverted internal fix from a previous version that caused an issue in this version of the driver.
JDBC Driver 3.0.9
- |SNOW-27121| Fixed an issue where the driver sometimes would hang if it encountered 403 errors while downloading large results. The driver now times out after 1 hour with no response from the application thread during download of results.
JDBC Driver 3.0.8
- |SNOW-25306| Improved performance by using the connection context when retrieving database metadata requests.
JDBC Driver 3.0.7
- |SNOW-26597| Fixed issue where the driver returns an error if the connecting application uses the
Statement.executeUpdate(String sql, int autoGeneratedKey)
API because the driver does not support auto-generated keys. The new version of the driver still does not support auto-generated keys; however, if the value forautoGeneratedKey
isStatement.NO_KEYS_RETURNED
, the driver now executes the statement successfully.
JDBC Driver 3.0.6
- |SNOW-26298| Fixed issue with invalid UTF-8 returned by driver when extracting data from a table into a file.
- |SNOW-18758| Forward-slash after the port number is now optional in the URL for the JDBC connect string.
JDBC Driver 3.0.5
- |SNOW-26032| Fixed issue with SNOWFLAKE_SAMPLE_DATABASE not being returned by
DatabaseMetadata.getCatalogs()
method. - |SNOW-25974| Fixed issue in Windows where PUT command failed if the filename was in quotes and contained backslashes.
JDBC Driver 3.0.4
- |SNOW-14445| Added support for pointing JDBC logger path to a directory other than
tmp
to prevent file permission issues.
JDBC Driver 3.0.3
- |SNOW-18243| Added support for case-insensitive searches on column names in result sets. By default, searches are case-sensitive. To request enabling case-insensitive search for your account, please contact Snowflake Support.
JDBC Driver 3.0.2
- |SNOW-25029| Fixed binding support for the TIME data type in the
PreparedStatement
API implementation. - |SNOW-25024, SNOW-24868| Implemented a fix to generate a user error when the client calls the
getData
,getTimestamp
, orgetTime
methods on columns with invalid data types. - |SNOW-24947| Fixed issue with GET command when it ends with a semicolon.
- |SNOW-24610| Updated javadoc related to an issue that caused the Informatica Cloud Snowflake Connector (v1) to fail with the following error:
invalid data encountered during decompression for file...
. - |SNOW-24884| Updated javadoc related to an issue where the Informatica Cloud Snowflake Connector (v1) treated all timestamps as UTC.
JDBC Driver 3.0.1
- |SNOW-24581, SNOW-24569| Fixed issue where an internal error was generated rather than a user error when attempting to convert a data type to an invalid data type.
JDBC Driver 3.0.0
- |SNOW-24544| Added support for AWS Signature JDBC Driver v4.
- |SNOW-23803| Migrated the classpath from
com.snowflake ...
tonet.snowflake ...
. - |SNOW-22351| Improved memory management for downloading large result sets.
JDBC Driver 2.8.2
- |SNOW-24335| Fixed issue where a file upload (PUT command) might not correctly close a file handle that was opened during this operation.
- |SNOW-21736| Driver now throws a user error instead of generating an incident if a closed
resultset
is fetched.
JDBC Driver 2.8.1
- |SNOW-23919| Fixed issue with timezone not being set correctly for the DATE data type, which resulted in date values not being returned correctly.
- |SNOW-23809| Improved the performance of the
Connection.getAutoCommit
API. - |SNOW-20904| Driver now available on central
mvn
nexus repository.