У меня есть сервер Ubuntu 12.04, и я пытаюсь установить соединение с базой данных MSSQL.
Мне удалось подключиться с помощью tsql
и isql
, но osql
не работает, и соединение с PHP с использованием PDO также не работает .. Я постараюсь предоставить как можно больше информации, и если вам нужно больше, просто дайте мне знать, и я отредактирую.
freetds.conf:
[MSSQL]
host = TPSACC
port = 54488
tds version = 8.0
odbc.ini:
[MSSQL]
Description = MS SQL connection to PRODUCTION database
Driver = FreeTDS
Database = PRODUCTION
Server = TPSACC
UserName = sa
Password = pass
Trace = No
TDS_Version = 8.0
Port = 54488
odbcinst.ini:
[FreeTDS]
Description = ODBC for Microsoft SQL
Driver = /usr/local/lib/libtdsodbc.so
UsageCount = 1
Threading = 2
~> isql MSSQL пройти
+---------------------------------------+
| Connected! |
| |
| sql-statement |
| help [tablename] |
| quit |
| |
+---------------------------------------+
SQL>
~> tsql -S MSSQL -U 'sa' -P 'пройти'
locale is "en_US.UTF-8"
locale charset is "UTF-8"
using default charset "UTF-8"
1>
~> osql -S MSSQL -U sa -P пройти
checking shared odbc libraries linked to isql for default directories...
strings: '': No such file
trying /tmp/sql ... no
trying /tmp/sql ... no
trying /etc ... OK
checking odbc.ini files
reading /home/toolplas/.odbc.ini
[MSSQL] not found in /home/toolplas/.odbc.ini
reading /etc/odbc.ini
[MSSQL] found in /etc/odbc.ini
found this section:
[MSSQL]
Description = MS SQL connection to PRODUCTION database
Driver = FreeTDS
Database = PRODUCTION
Server = TPSACC
UserName = sa
Password = pass
Trace = No
TDS_Version = 8.0
Port = 54488
looking for driver for DSN [MSSQL] in /etc/odbc.ini
found driver line: " Driver = FreeTDS"
driver "FreeTDS" found for [MSSQL] in odbc.ini
found driver named "FreeTDS"
"FreeTDS" is not an executable file
looking for entry named [FreeTDS] in /etc/odbcinst.ini
found driver line: " Driver = /usr/local/lib/libtdsodbc.so"
found driver /usr/local/lib/libtdsodbc.so for [FreeTDS] in odbcinst.ini
/usr/local/lib/libtdsodbc.so is an executable file
"Server" found, not using freetds.conf
Server is "TPSACC"
osql: no IP address found for "TPSACC"
В PHP у меня есть:
$conn = new PDO ("dblib:host=TPSACC;dbname=PRODUCTION","$username","$pw");
..или..
$conn = new PDO ("dblib:host=TPSACC;port=54488;dbname=PRODUCTION","$username","$pw");
И они оба возвращают эту ошибку:
SQLSTATE[HY000] Unable to connect: Adaptive Server is unavailable or does not exist (severity 9)
Я застрял здесь на пару дней и не могу понять, почему на самом деле работает только половина соединений ...
Любая помощь очень ценится, спасибо!
Установлены модули PHP?
Создать info.php
файл на вашем веб-сервере (apache2 dir: /var/www/html
в Ubuntu) с <?php phpinfo() ?>
для просмотра подробностей. Использовать odbcinst -j
для загрузки файлов конфигурации с помощью unixODBC и tsql -C
для получения реквизитов FreeTDS; проверьте, есть ли MS db-lib source compatibility: yes
.
Если MS db-lib
нет, вам нужно настроить freetds с --enable-msdblib
.
Мой ./configure
линия:
./configure --with-tdsver=8.0 --with-unixodbc=/usr/local --enable-msdblib
затем sudo make && sudo make install
Это мой рабочий конфиг:
Freetds.conf:
[MSSQL]
host = 192.168.1.200
port = 1433
tds version = 8.0
client charset = UTF-8
odbc.ini:
[mssql]
Description = MSSQL Server
Driver = freetds #The odbcinst.ini driver name
ServerName = MSSQL # The Freetds.conf connection name
Database = database
TDS_Version = 8.0
odbcinst.ini
[freetds]
Description = MS SQL database access with Free TDS
Driver = /usr/lib/libtdsodbc.so
Setup = /usr/lib/x86_64-linux-gnu/odbclibtdsS.so
UsageCount = 1