ohh*_*hho 8 sql-server macos odbc unixodbc freetds
odbc isql
无法连接到数据源:
$ isql SMS_GTWY username password -v
Run Code Online (Sandbox Code Playgroud)
收益:
[S1000][unixODBC][FreeTDS][SQL Server]Unable to connect to data source
[01000][unixODBC][FreeTDS][SQL Server]Unknown host machine name.
[ISQL]ERROR: Could not SQLConnect
Run Code Online (Sandbox Code Playgroud)
虽然没问题tsql
:
$ tsql -S SERVER001 -U username -P password
Run Code Online (Sandbox Code Playgroud)
收益:
locale is "C/UTF-8/C/C/C/C"
locale charset is "UTF-8"
using default charset "UTF8"
1>
Run Code Online (Sandbox Code Playgroud)
$ cat ~/.freetds.conf
:
[SERVER001]
host = 192.168.8.101
port = 1433
tds version = 8.0
client charset = UTF8
Run Code Online (Sandbox Code Playgroud)
$ cat ~/.odbc.ini
:
[SMS_GTWY]
Description = SERVER001 Server
Driver = freetds
Database = SMS_GTWY
ServerName = SERVER001
TDS_Version = 7.1
Run Code Online (Sandbox Code Playgroud)
$ cat ~/.odbcinst.ini
:
[freetds]
Description = MS SQL database access with FreeTDS
Driver = /usr/local/lib/libtdsodbc.so
Setup = /usr/local/lib/libtdsodbc.so
UsageCount = 1
Run Code Online (Sandbox Code Playgroud)
freetds
并unixODBC
在家安装brew
.
我有一个类似的设置在CentOS和odbc isql到mssqlserver工作正常.有一个明显的区别,我没有libtdsS.so
在OS X上看到安装.
# cat /etc/odbcinst.ini
在CentOS上:
[freetds]
Description = MS SQL database access with FreeTDS
Driver = /usr/lib/libtdsodbc.so
Setup = /usr/lib/libtdsS.so
UsageCount = 1
Run Code Online (Sandbox Code Playgroud)
这是问题的原因吗?
ps $ odbcinst -j
返回:
unixODBC 2.3.1
DRIVERS............: /usr/local/Cellar/unixodbc/2.3.1/etc/odbcinst.ini
SYSTEM DATA SOURCES: /usr/local/Cellar/unixodbc/2.3.1/etc/odbc.ini
FILE DATA SOURCES..: /usr/local/Cellar/unixodbc/2.3.1/etc/ODBCDataSources
USER DATA SOURCES..: /Users/horace/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8
Run Code Online (Sandbox Code Playgroud)
$ odbcinst -q -d
收益:
[freetds]
Run Code Online (Sandbox Code Playgroud)
$ odbcinst -q -s
收益:
[SMS_GTWY]
Run Code Online (Sandbox Code Playgroud)
isql
重新安装unixodbc
和freetds
(--with-unixodbc
)后工作:
brew uninstall freetds
brew uninstall unixodbc
brew install unixodbc
brew install freetds --with-unixodbc
Run Code Online (Sandbox Code Playgroud)
现在,$ isql -v SMS_GTWY username password
返回:
+---------------------------------------+
| Connected! |
| |
| sql-statement |
| help [tablename] |
| quit |
| |
+---------------------------------------+
SQL>
Run Code Online (Sandbox Code Playgroud)
信用:https://gist.github.com/565440
归档时间: |
|
查看次数: |
11228 次 |
最近记录: |