Releases: microsoft/msphpsql
5.13.0-beta1 for PHP Driver for SQL Server
Added
- Support for PHP 8.4
- Support for Windows Server 2025
- Support for Ubuntu 24.04
- Support for Debian 12 and 13
- Support for Red Hat 9
- Support for Alpine 3.21, 3.22, and 3.23
- Support for macOS 14, 15, and 26
Removed
- Support for PHP 8.1
- Support for Windows 10, Server 2012, and Server 2012 R2
- Support for Ubuntu 20.04
- Support for Debian 10
- Support for macOS 11 and 12
Fixed
- Fixed segfault when connecting to Fabric (PR #1549)
- Enhanced error reporting in PDO driver when ODBC diagnostic retrieval fails (PR #1549)
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Click here to start the PHP survey
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.13.0beta1
sudo pecl install pdo_sqlsrv-5.13.0beta1 - Windows DLLs can be found in
Assets
5.12.0 for PHP Driver for SQL Server
Added
-Support for PHP 8.3
-Support for Alpine 3.19
Removed
-Support for PHP 8.0
-Support for Ubuntu 18.04
-Support for Alpine 3.15
Fixed
-Update connection string keywords set function (#1484)
-Fix error throw for multiple result sets (#1485)
-Fix invalid precision error (#1497)
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Click here to start the PHP survey
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.12.0
sudo pecl install pdo_sqlsrv-5.12.0 - Windows DLLs can be found in
Assets
5.12.0-beta1 for PHP Driver for SQL Server
Added
- Support for PHP 8.3
Removed
- Support for PHP 8.0
- Support for Ubuntu 18.04
Fixed
- Update connection string keywords set function (#1484)
- Fix error throw for multiple result sets (#1485)
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Click here to start the PHP survey
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.12.0beta1
sudo pecl install pdo_sqlsrv-5.12.0beta1 - Windows DLLs can be found in
Assets
5.11.1 for PHP Driver for SQL Server
Fixed
- Reset type after bind param (#1452)
- Fixed error when using PDO::ATTR_STRINGIFY_FETCHES (#1468) by SakiTakamachi
- Change connection options to case insensitive (#1460)
- Bugfix for 1465 Adding a NULL check (#1471)
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Click here to start the PHP survey
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.11.1
sudo pecl install pdo_sqlsrv-5.11.1 - Windows DLLs can be found in
Assets
5.11.0 for PHP Driver for SQL Server
Added
- Support for PHP 8.2
Removed
- Support for PHP 7.4
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Click here to start the PHP survey
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.11.0
sudo pecl install pdo_sqlsrv-5.11.0 - Windows DLLs can be found in
Assets
5.11.0-beta1 for PHP Driver for SQL Server
Added
- Support for PHP 8.2
Fixed
- Pull request #1408 - Fixed right truncation issue, unit test added by talkinnl
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Click here to start the PHP survey
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.11.0beta1
sudo pecl install pdo_sqlsrv-5.11.0beta1 - Windows DLLs can be found in
Assets
5.10.1 for PHP Driver for SQL Server
Added
- Pull request #1382 - Support for ActiveDirectoryIntegrated authentication
Fixed
- Pull request #1374 - Fixed ActiveDirectoryMsi Authentication behavior when specified UID by laclefyoshi
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.10.1
sudo pecl install pdo_sqlsrv-5.10.1 - To download Windows DLLs for PHP 7.4 or above from the PECL repository, please navigate to SQLSRV or PDO_SQLSRV.
5.10.0 for PHP Driver for SQL Server
Added
- Support for PHP 8.1
- Support for macOS Monterey, Debian 11, Ubuntu 21.04 and 21.10, Alpine 3.13, 3.14 and 3.15
- Support for Apple M1 ARM64 hardware -- requires MS ODBC Driver 17.8+
- Adjusted connection keyword and value validation for more flexibility
- Feature Request #795 - adding support for Table-valued parameters
- Feature Request #1320 - allow PDO::ATTR_EMULATE_PREPARES to be set at the connection level
Removed
- Support for PHP 7.3
- Support for Ubuntu 16.04, Alpine 3.11 and Alpine 3.12
Fixed
- Issue #1244 - use lower case for object names for PDO::lastInsertId() - pull request #1245 by morozov
- Pull request #1251 - simplified implementations of last insert id and quote
- Issue #1258 - updated pdo_sqlsrv_get_driver_methods as per documentation - pull request #1259
- Pull request #1260 - cleaned up redundant code
- Issue #1261 - simplified get_field_as_string and made it more robust - pull request #1265
- Pull request #1262 - simplified parse_param_array in sqlsrv
- Pull request #1267 - replaced the obsolete MACRO ZVAL_NEW_ARR with array_init
- Pull request #1275 - fixed warning compiling core_stmt.cpp by mlocati
- Pull request #1288 - applied mask to pdo quote for binary inputs
- Pull request #1290 - updated list of supported processor architecture
- Issue #1307 - added TVP support to non-procedure statements
- Issue #1310 - adjusted sql_data_type and column size for NULL parameters - pull request #1311 by gjcarrette
- Pull request #1326 - php drivers simply pass Azure AD Authentication to ODBC driver, which will verify the settings
- Issue #1329 - reset sql type and column size for input params
- Issue #1331 - restore PDO::ATTR_ERRMODE if calling PDO::lastInsertId() call fails - pull request #1330 by mpyw and pull request #1332
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.10.0
sudo pecl install pdo_sqlsrv-5.10.0 - To download Windows DLLs for PHP 7.4 or above from the PECL repository, please navigate to SQLSRV or PDO_SQLSRV.
5.10.0-beta2 for PHP Driver for SQL Server
Added
- Support for PHP 8.1
- Support for Ubuntu 21.10
- Feature Request #1320 - allow PDO::ATTR_EMULATE_PREPARES to be set at the connection level
Fixed
- Issue #1307 - added TVP support to non-procedure statements
- Issue #1310 - adjusted sql_data_type and column size for NULL parameters - pull request #1311 by gjcarrette
- Pull request #1326 - php drivers simply pass Azure AD Authentication to ODBC driver, which will verify the settings
- Issue #1329 - reset sql type and column size for input params
- Issue #1331 - restore PDO::ATTR_ERRMODE if calling PDO::lastInsertId() call fails - pull request #1330 by mpyw and pull request #1332
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.10.0beta2
sudo pecl install pdo_sqlsrv-5.10.0beta2 - To download Windows DLLs for PHP 7.3 or above from the PECL repository, please navigate to SQLSRV or PDO_SQLSRV.
5.10.0-beta1 for PHP Driver for SQL Server
Added
- Support for PHP 8.1 RC 1
- Support for Ubuntu 21.04 and Alpine 3.13
- Support for Apple M1 ARM64 hardware (requires MS ODBC Driver 17.8+)
- Feature Request #795 - adding support for Table-valued parameters
Removed
- Support for Ubuntu 16.04
Fixed
- Issue #1244 - use lower case for object names for PDO::lastInsertId() - pull request #1245 by morozov
- Pull request #1251 - simplified implementations of last insert id and quote
- Issue #1258 - updated pdo_sqlsrv_get_driver_methods as per documentation - pull request #1259
- Pull request #1260 - cleaned up redundant code
- Issue #1261 - simplified get_field_as_string and made it more robust - pull request #1265
- Pull request #1262 - simplified parse_param_array in sqlsrv
- Pull request #1267 - replaced the obsolete MACRO ZVAL_NEW_ARR with array_init
- Pull request #1275 - fixed warning compiling core_stmt.cpp by mlocati
- Pull request #1288 - applied mask to pdo quote for binary inputs
- Pull request #1290 - updated list of supported processor architecture
Limitations
- No support for inout / output params when using sql_variant type
- No support for inout / output params when formatting decimal values
- In Linux and macOS, setlocale() only takes effect if it is invoked before the first connection. Attempting to set the locale after connecting will not work
- Always Encrypted requires MS ODBC Driver 17+
- Only Windows Certificate Store and Azure Key Vault are supported. Custom Keystores are not yet supported
- Issue #716 - With Always Encrypted enabled, named parameters in subqueries are not supported
- Issue #1050 - With Always Encrypted enabled, insertion requires the column list for any tables with identity columns
- Always Encrypted limitations
Known Issues
- This release requires ODBC Driver 17.4.2 or above. Otherwise, a warning about failing to set an attribute may be suppressed when using an older ODBC driver.
- Connection pooling on Linux or macOS is not recommended with unixODBC < 2.3.7
- When pooling is enabled in Linux or macOS
- unixODBC <= 2.3.4 (Linux and macOS) might not return proper diagnostic information, such as error messages, warnings and informative messages
- due to this unixODBC bug, fetch large data (such as xml, binary) as streams as a workaround. See the examples here
Survey
Let us know how we are doing and how you use our drivers by taking our pulse survey:
Install
- On Linux and macOS run the commands below:
sudo pecl install sqlsrv-5.10.0beta1
sudo pecl install pdo_sqlsrv-5.10.0beta1 - To download Windows DLLs for PHP 7.3 or above from the PECL repository, please navigate to SQLSRV or PDO_SQLSRV.
