v5:database:microsoft_sql_server
                Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| v5:database:microsoft_sql_server [2016/01/13 02:06] – ↷ Links adapted because of a move operation mnewnham | v5:database:microsoft_sql_server [2025/06/01 13:21] (current) – Remove square brackets in tags dregad | ||
|---|---|---|---|
| Line 2: | Line 2: | ||
| ~~NOTOC~~ | ~~NOTOC~~ | ||
| ===== Description ===== | ===== Description ===== | ||
| - | There are 2 supported drivers that allow connections to Microsoft SQL Server databases. | + | There are 2 supported drivers that allow connections to Microsoft SQL Server databases | 
| - | ==== SQL Server 2003 ==== | + | ==== mssqlnative | 
| - | Connecting to SQL server 2003 creates a difficulty There is no support for native client | + | This driver, which runs on both Windows and Linux clients, | 
| - | ------------------------------------ | + | |
| + | More about the Microsoft SQL Server client for Linux [[https:// | ||
| + | |||
| + | ==== mssql==== | ||
| + | This allows | ||
| + | |||
| + | More about the FreeTDS | ||
| ====== mssqlnative ====== | ====== mssqlnative ====== | ||
| <WRAP right box round 300px> | <WRAP right box round 300px> | ||
| Line 13: | Line 20: | ||
| ^Status|Active((This driver is actively supported by ADOdb project members))| | ^Status|Active((This driver is actively supported by ADOdb project members))| | ||
| ^Windows|Yes| | ^Windows|Yes| | ||
| - | ^Unix|No| | + | ^Unix|Yes| | 
| ^ADOdb V5|Yes| | ^ADOdb V5|Yes| | ||
| ^ADOdb V6|Yes| | ^ADOdb V6|Yes| | ||
| Line 19: | Line 26: | ||
| [[v5: | [[v5: | ||
| [[v5: | [[v5: | ||
| + | == See Also == | ||
| + | [[v5: | ||
| </ | </ | ||
| - | **This is the preferred driver for connecting to a SQL server database from Windows clients.** | + | **This is the preferred driver for connecting to a SQL server database from both Windows | 
| - | This driver was contributed by Microsoft and provides connections to SQL server databases greater than version 2000. It requires PHP version 5.3 or greater, Microsoft native client software and the appropriate PHP driver. | + | The original | 
| + | * On Windows clients, | ||
| + | * On Linux clients, PHP version 7.0 and higher is required. | ||
| Sequences are supported in native mode in SQL Sever 2012, and emulated in earlier versions. | Sequences are supported in native mode in SQL Sever 2012, and emulated in earlier versions. | ||
| Line 38: | Line 49: | ||
| - | However, in order to improve portability, | + | However, in order to improve portability, | 
| [RequiredDate] => 1996-08-01 00: | [RequiredDate] => 1996-08-01 00: | ||
| Line 44: | Line 55: | ||
| In order to return the dateTime as an object, the following action is required: | In order to return the dateTime as an object, the following action is required: | ||
| <code php> | <code php> | ||
| - | + | $db = ADONewConnection(' | |
| - | $db = newAdoConnection(' | + | |
| $db-> | $db-> | ||
| $db-> | $db-> | ||
| </ | </ | ||
| - | ------------------------------------ | ||
| - | <WRAP right box round 300px> | ||
| - | This behaviour is only available in ADOdb V 5.21.0 and higher | ||
| - | </ | ||
| - | === Modifying The Format Of The Date === | ||
| - | When methods like [[v5: | ||
| + | ===== Unicode Strings ===== | ||
| + | You can set the character set to UTF-8 using: | ||
| <code php> | <code php> | ||
| - | /** | + | $db = ADONewConnection(' | 
| - | * Create the same column Against a MySQL, Oracle, SQL Server database | + | $db->setConnectionParameter('characterSet',' | 
| - | */ | + | $db->connect('SERVER\SQLEXPRESS',' | 
| - | $dict->addColumnSql('some_table',' | + | |
| - | + | ||
| - | /* | + | |
| - | * Retrieve the data from column | + | |
| - | */ | + | |
| - | $d = $db->getOne('SELECT some_date_column FROM some_table'); | + | |
| - | + | ||
| - | print $d; | + | |
| - | + | ||
| - | /* | + | |
| - | * With SQL Server, prints | + | |
| - | * With Other Databases, prints | + | |
| - | */ | + | |
| </ | </ | ||
| - | To create a portable application, | + | ===== Using Windows Authentication ===== | 
| + | To use Windows, instead of SQL Server authentication, | ||
| <code php> | <code php> | ||
| - | $db = newAdoConnection(' | + | $db = ADONewConnection(' | 
| - | $db-> | + | $db-> | 
| - | $db-> | + | </ | 
| - | $d = $db-> | + | ===== Common Connection Problems ===== | 
| + | Recent versions of SQL Server fail to connect with an error '' | ||
| - | print $d; | + | This problem can be resolved by adding | 
| - | /* | + | <code php> | 
| - | * Now prints a compatible value 1996-07-16 | + | $db-> | 
| - | */ | + | |
| </ | </ | ||
| - | This setting modifies | + | before issuing | 
| - | $db-> | ||
| - | to modify | + | ------------------------------ | 
| + | ===== How to create a connection under Linux ===== | ||
| + | Establishing a connection to a SQL server database from a Linux client can be difficult, but by installing the freetds tools as well as the Microsoft ones provides a highly useful tool, // | ||
| - | ** These settings have no effect if '' | + | In the example, our database | 
| + | < | ||
| + | # tsql -LH 192.168.0.65 | ||
| + | ServerName STUDY | ||
| + |  | ||
| + | IsClustered No | ||
| + | Version 12.0.2000.8 | ||
| + | tcp 55644 | ||
| + | np \\STUDY\pipe\MSSQL$SQLEXPRESS\sql\query | ||
| + | </ | ||
| + | The response from the command tells us the | ||
| + |  | ||
| + |  | ||
| + | We can now create a connection string: | ||
| - | ------------------------------ | + | <code php> | 
| + | $db = ADONewConnection(' | ||
| + | $db-> | ||
| + | </ | ||
| + | -------------------------------------- | ||
| ===== mssql (Unix) ===== | ===== mssql (Unix) ===== | ||
| Line 115: | Line 126: | ||
| [[v5: | [[v5: | ||
| </ | </ | ||
| - | **This is the preferred driver for connecting to a SQL server database from Linux/Unix clients.** | + | **This is the preferred driver for connecting to a SQL server database from Linux/Unix clients, when the PHP version is less than 7.0** | 
| This driver provides access to Microsoft SQL Server databases from unix systems via Freetds | This driver provides access to Microsoft SQL Server databases from unix systems via Freetds | ||
| - | {{tag>[SQL_Server unix active freetds]}} | + | {{tag> | 
| -------------------------------------- | -------------------------------------- | ||
| ===== mssql (Windows) ===== | ===== mssql (Windows) ===== | ||
| Line 149: | Line 160: | ||
| This driver provides undocumented portability extensions to the Unix mssql driver | This driver provides undocumented portability extensions to the Unix mssql driver | ||
| - | {{tag>[SQL_Server unix windows active portable]}} | + | {{tag> | 
| ===== mssql_n ===== | ===== mssql_n ===== | ||
| Line 162: | Line 173: | ||
| ^ADOdb V6|Yes| | ^ADOdb V6|Yes| | ||
| </ | </ | ||
| - | This driver appears to provide Unicode enhancements to the mssql driver | + | This driver appears to provide Unicode enhancements to the mssql driver. You can set character sets using the [[v5: | 
| - | {{tag>[" | + | {{tag>" | 
v5/database/microsoft_sql_server.1452647183.txt.gz · Last modified:  (external edit)
                
                