1. 下载

官网地址unixODBC

2.安装

2.1将tar包上传到服务器/usr/local

执行tar xvf unixODBC*.tar.gz

2.2编译(以下命令依次执行)

./configure

make

make install

2.3测试

odbcinst -j

安装成功:显示版本号和驱动地址

 

安装失败:

终端显示:odbcinst: error while loading shared libraries: libodbcinst.so.2: cannot open shared object file: No such file or directory

错误处理:

  安装共享库后要注意共享库路径设置问题, 如下:

  (1)如果库文件安装到了/lib或/usr/lib目录下:

    那么需在该目录下执行一下ldconfig命令;

    ldconfig命令的用途, 主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下, 搜索出可共享的动态链接库(格式如lib*.so*),

    进而创建出动态装入程序(ld.so)所需的连接和缓存文件.  缓存文件默认为/etc/ld.so.cache, 此文件保存已排好序的动态链接库名字列表. 

  (2)如果共享库文件安装到了/usr/local/lib(很多开源的共享库都会安装到该目录下)或其它"非/lib或/usr/lib"目录下:

    那么在执行ldconfig命令前, 还要把新共享库目录加入到共享库配置文件/etc/ld.so.conf中,如下:

# cat /etc/ld.so.conf

include ld.so.conf.d/*.

  (3)如果共享库文件安装到了其它"非/lib或/usr/lib" 目录下,  但是又不想在/etc/ld.so.conf中加路径(或者是没有权限加路径):

     那可以export一个全局变量LD_LIBRARY_PATH,然后运行程序的时候就会去这个目录中找共享库.   

     LD_LIBRARY_PATH的意思是告诉loader在哪些目录中可以找到共享库. 可以设置多个搜索目录, 这些目录之间用冒号分隔开.

     比如安装了一个mysql到/usr/local/mysql目录下, 其中有一大堆库文件在/usr/local/mysql/lib下面,  则可以在.bashrc或.bash_profile或shell里加入以下语句即可: 

    export LD_LIBRARY_PATH=/usr/local/mysql/lib:$LD_LIBRARY_PATH  

    一般来讲这只是一种临时的解决方案, 在没有权限或临时需要的时候使用.

  • 如何使用

以MySQL数据源为例

进入unixODBC安装目录/exe,执行odbcinst -j,可以得到驱动和数据源的路径,后面用得到

  1. 安装mysql驱动

使用yum安装 yum install mysql-connector-odbc,连接其他数据库,则需要安装其他数据库驱动

安装完成后在/etc/odbcinst.ini里会自动添加一段mysql驱动的配置,将此配置复制出来

 

  1. 配置驱动

vim /usr/local/etc/odbcinst.ini 将上个步骤中mysql驱动的配置复制到ini文件中

[MySQL]

Description=ODBC for MySQL

Driver=/usr/lib/libmyodbc5.so

Setup=/usr/lib/libodbcmyS.so

Driver64=/usr/lib64/libmyodbc5.so

Setup64=/usr/lib64/libodbcmyS.so

FileUsage=1

  1. 配置数据源

vim /usr/local/etc/odbc.ini

[my182]

Driver=MySQL

SERVER=本地IP

PORT=3306(端口号)

USER=root

PASSWORD=MySQL数据库root用户的密码

ADTABASE=sample

  1. 访问数据库

进入unixODBC安装目录下的exe文件夹

执行isql -v [数据源名称]

连接成功

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐