LINUX安装ODBC驱动

本文详细介绍UnixODBC 2.3.1版本的下载、安装步骤及配置方法,并解决了安装过程中可能出现的共享库文件找不到的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、先下载最新的unixODBC源码包( http://www.unixodbc.org/unixODBC-2.3.1.tar.gz)放到/usr/local下

      解压:

tar -zxvf unixODBC-2.3.1.tar.gz
2、安装unixODBC-2.3.1.tar.gz

#cd usr/local/unixODBC-2.3.1/
#./configure --prefix=/usr/local/unixODBC-2.3.1 --includedir=/usr/include --libdir=/usr/lib -bindir=/usr/bin --sysconfdir=/etc
#make
#make install


3、测试查看unixODBC安装情况

#odbcinst -j
unixODBC 2.3.1  
DRIVERS............: /etc/odbcinst.ini  
SYSTEM DATA SOURCES: /etc/odbc.ini  
FILE DATA SOURCES..: /etc/ODBCDataSources  
USER DATA SOURCES..: /root/.odbc.ini  
SQLULEN Size.......: 8  
SQLLEN Size........: 8  
SQLSETPOSIROW Size.: 8 

PS:安装完成后,查看unixODBC安装情况,可能会报如下错误:

#odbcinst -j
odbcinst: error while loading shared libraries: libodbcinst.so.2: cannot open shared object file: No such file or directory


解决办法:
安装共享库后要注意共享库路径设置问题, 如下:
A、如果共享库文件安装到了/lib或/usr/lib目录下, 那么需执行一下ldconfig命令
ldconfig命令的用途, 主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下, 搜索出可共享的动态链接库(格式如lib*.so*), 进而创建出动态装入程序(ld.so)所需的连接和缓存文件. 
缓存文件默认为/etc/ld.so.cache, 此文件保存已排好序的动态链接库名字列表. 
B、如果共享库文件安装到了/usr/local/lib(很多开源的共享库都会安装到该目录下)或其它"非/lib或/usr/lib"目录下, 那么在执行ldconfig命令前, 还要把新共享库目录加入到共享库配置文件/etc/ld.so.conf中, 如下:

# cat /etc/ld.so.conf
include ld.so.conf.d/*.conf
# echo "/usr/local/lib" >> /etc/ld.so.conf
# cat /etc/ld.so.conf
include ld.so.conf.d/*.conf
/usr/local/lib
# ldconfig


C、如果共享库文件安装到了其它"非/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    
一般来讲这只是一种临时的解决方案, 在没有权限或临时需要的时候使用

Linux系统上安装ODBC(开放数据库连接)后,如果没有自动创建ODBC.ini文件,这通常是因为ODBC的配置管理是由系统管理员或特定的包管理器如`libodbc1`、`unixodbc`或`freedbsql`等负责的,而不是由标准用户自动生成的。 当你手动安装ODBC驱动或通过包管理器完成安装后,ODBC.ini文件可能会存放在一些默认路径,如`/etc/odbcinst.ini`或`~/.odbc.ini`(对于个人用户的配置)。如果没有找到该文件,你可以尝试以下步骤: 1. **检查默认位置**:确认ODBC是否在预期的位置创建了ini文件。可以使用`ls -l /etc/odbcinst.ini ~/.odbc.ini`命令查看这两个目录。 2. **手动创建**:如果文件不存在,可以自行创建一个,并指定你要连接的数据库驱动和相关的参数。例如,在`/etc/odbcinst.ini`下添加: ``` [Driver_Name] Description=Your Driver Description File=/path/to/your/driver/libodbc_driver.so ``` 3. **更新环境变量**:确保`$LD_LIBRARY_PATH`包含了ODBC驱动所在的目录,以便系统能找到它。 4. **重启服务**:有时候可能需要重启ODBC或系统服务,让新的配置生效。比如运行`sudo systemctl restart odbc.service`(取决于你的Linux发行版和具体的ODBC设置)。 5. **验证设置**:最后,使用`isql`工具测试新添加的驱动,看能否成功连接到数据库。 如果你仍然找不到ODBC.ini文件,或者遇到其他问题,建议查阅系统的官方文档,或者在网上搜索针对你所使用的Linux发行版和ODBC版本的具体教程。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值