Connecting PHP to Microsoft SQL Server on Linux
Here is how to get PHP 5.2 on Linux (specifically Debian/Ubuntu) talking to a Microsoft SQL Server database:
1. Install FreeTDS and the PHP MS SQL extension$ sudo apt-get install freetds-common freetds-bin unixodbc php5-sybase
Note: That is correct, the MS SQL extension is in the “php5-sybase” package.
2. Restart Apache$ sudo /etc/init.d/apache2 restart
3. Test FreeTDS$ tsql -H your.server.name -p 1433 -U yourusername -P yourpassword -D yourdatabasename
If it connects, it’s working. Note: If you try to SELECT an NTEXT or NVARCHAR column you may get an error saying “Unicode data in a Unicode-only collation or ntext data cannot be sent to clients using DB-Library (such as ISQL) or ODBC version 3.7 or earlier”. That is expected and will be fixed in the next step.
4. Configure FreeTDS$ sudo vim /etc/freetds/freetds.conf
Add this at the end of the file:[yourserver]
host = your.server.name
port = 1433
tds version = 8.0
5. Test FreeTDS using server name$ tsql -S yourserver -U yourusername -P yourpassword -D yourdatabasename
If you try to select something, you shouldn’t get the Unicode error now – because you specified “tds version = 8.0”.
6. Test in PHP$link = mssql_connect('yourserver', 'yourusername', 'yourpassword');
if (!$link)
die('Unable to connect!');
if (!mssql_select_db('yourdatabasename', $link))
die('Unable to select database!');
$result = mssql_query('SELECT * FROM yourtable');
while ($row = mssql_fetch_array($result)) {
var_dump($row);
}
mssql_free_result($result);
Source link: https://davejamesmiller.com/blog/connecting-php-to-microsoft-sql-server-...
T-SQL manual page: https://linux.die.net/man/1/tsql