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 line
const 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
一般來講這只是一種臨時的解決方案, 在沒有權限或臨時需要的時候使用.
採用第二種解決方法。解決了問題,完成安裝