top
Loading...
A.3.1.與MySQL客戶端庫的鏈接問題
A.3.1. 與MySQL客戶端庫的鏈接問題

當你鏈接到應用程序以使用MySQL客戶端庫時,可能會遇到以mysql_開始的未定義引用錯誤,如下所示:

/tmp/ccFKsdPa.o: 在函數`main':
/tmp/ccFKsdPa.o(.text+0xb): `mysql_init'的未定義引用。
/tmp/ccFKsdPa.o(.text+0x31): `mysql_real_connect'的未定義引用。
/tmp/ccFKsdPa.o(.text+0x57): `mysql_real_connect'的未定義引用。
/tmp/ccFKsdPa.o(.text+0x69): `mysql_error'的未定義引用。
/tmp/ccFKsdPa.o(.text+0x9a): `mysql_close'的未定義引用。

通過在鏈接命令后增加“-Ldir_path -lmysqlclient”選項,應能解決該問題,其中,dir_path代表客戶端庫所在目錄的路徑名。要想確定正確的目錄,可嘗試下述命令:

shell> mysql_config --libs

來自mysql_config的輸出可能會指明應在鏈接命令上指定的其他庫。

對于非壓縮或壓縮函數,如果遇到未定義引用錯誤,可在鏈接命令后添加-lz,并再次嘗試。

對于應在系統上存在的函數(如connect),如果遇到未定義引用錯誤,請檢查相關函數的手冊頁,以便確定應在鏈接命令上增加哪些庫。

對于系統上不存在的函數,可能會遇到未定義引用錯誤,如下所示:

mf_format.o(.text+0x201): `__lxstat'的未定義引用。

它通常意味著你的MySQL客戶端庫是在與你的系統不100%兼容的系統上編譯的。在該情況下,應下載最新的MySQL源碼分發版,并自己編譯MySQL。請參見2.8節,“使用源碼分發版安裝MySQL”。

當你試圖執行MySQL程序時,可能會遇到運行時未定義引用錯誤。如果這類錯誤指明了以mysql_開始的符號,或指明未發現mysqlclient,這意味著你的系統無法找到共享的libmysqlclient.so庫。對其的更正方式是,通知系統在庫所在位置搜索共享庫。請使用與系統相適應的下述方法:

·         libmysqlclient.so所在目錄的路徑添加到LD_LIBRARY_PATH環境變量中。

·         libmysqlclient.so所在目錄的路徑添加到LD_LIBRARY環境變量中。

·         libmysqlclient.so拷貝到可被系統搜索的目錄下,如/lib,然后通過執行ldconfig更新共享庫信息。

解決該問題的另一種方法是,以靜態方式將你的程序與“-static”選項鏈接在一起,或在鏈接代碼之前刪除動態MySQL庫。使用第2種方法之前,應確保沒有使用動態庫的其它程序。

作者:mysql.com
來源:http://dev.mysql.com/doc/refman/5.1/zh/problems.html
北斗有巢氏 有巢氏北斗