mysql++ 中遇到的安装问题 及linux下C++添加共享库
来源:互联网 发布:兄弟连java 怎么样 编辑:程序博客网 时间:2024/06/07 16:48
linux下安装mysql++
官方网站下载mysql++
tar 命令解压
./configure --prefix=/local //安装路径自定义
问题:
checking for MySQL library directory... configure: error: Didn't find mysqlclient library in '/usr/lib64 /usr/lib /usr/lib64/mysql /usr/lib/mysql /usr/local/lib64 /usr/local/lib /usr/local/lib/mysql /usr/local/mysql/lib /usr/local/mysql/lib/mysql /usr/mysql/lib/mysql /opt/mysql/lib /opt/mysql/lib/mysql /sw/lib /sw/lib/mysql'
解决方法:sudo apt-get install libmysqlclient
然后locate libmysqlclient去查找你的系统中的libmysqlclient.so library在哪个文件下(我的/usr/lib/x86_64-linux-gnu)
注意:(使用locate之前先sudo updatedb手动更新数据库下,因为locate是经过数据库来查找的,而数据库默认自动更新是一天一次。这样可能导致你locate不到今天刚刚生成的文件)
重新使用命令:./configure --prefix=/local --with-mysql-lib=/usr/lib/x86_64-linux-gnu
问题消除 ,
make
sudo make install
测试连接mysql demo
#include <mysql++.h>#include <iostream>using namespace std;int main(int argc, char *argv[]){// Get database access parameters from command lineconst char* db = 0, *server = 0, *user = 0, *password = "";db = "healthcareweb";server = "11.0.17.208";user = "root";password = "123456";// Connect to the sample database.mysqlpp::Connection conn(false);if (conn.connect(db, server, user, password)) {cout << "success. " << endl;} else {cout << "false. " << endl;}return 0;}
g++ -o main main.cpp -I /home/onejian/local/include/mysql++ -I /usr/include/mysql -L /home/onejian/local/lib -lmysqlpp
(/home/onejian/local/即安装的路径,另外mysql_version.h在/usr/include/mysql中所以需要添加,-L 包含库的路径)
遇到问题:
error while loading shared libraries: libmysqlpp.so.3: 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/*.conf
# echo "/usr/local/lib" >> /etc/ld.so.conf
# ldconfig
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++ 中遇到的安装问题 及linux下C++添加共享库
- Linux下安装MySQL遇到的问题
- Linux下安装MySQL遇到的问题
- Linux下安装MySQL遇到缺少libncurses库的问题
- linux下mysql安装和安装遇到的问题
- mysql 安装及安装中遇到的问题
- Linux 安装mysql 遇到的问题及解决办法
- Linux Ubuntu安装MySql 遇到的问题及解决方案
- linux系统下mysql安装过程中遇到的问题与解决方法
- linux下安装cmake和mysql遇到的问题总结
- SUSE Linux Ubuntu 下安装mysql遇到的问题一。
- Mysql安装过程中遇到的问题及解决办法
- centos7中源码安装mysql过程及遇到的问题
- linux 下安装android遇到的问题及解决
- linux 操作系统下安装oracle遇到的问题及解决方法
- linux下安装sqlite及遇到的问题
- linux下redis安装遇到的问题及解决办法
- linux环境下hadoop安装遇到的问题及解决办法
- XML---<merge/> 和 <include/>
- mysql update 无法使用子查询。。。
- UVa 10499 The Land of Justice(简单数学)
- 看懂信息检索和网络数据挖掘领域论文的必备知识总结
- Kinect应用开发汇总
- mysql++ 中遇到的安装问题 及linux下C++添加共享库
- hdu 1176 免费馅饼 (数塔)
- linux内核分析笔记----虚拟文件系统(下)
- 算法入门经典-1
- POJ-2191-Mersenne Composite Numbers
- sky数
- ubuntu12.04samba服务器配置
- 话题模型(topic model)的提出及发展历史
- android4.2 锁屏源码分析