欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用Autoconf檢測(cè)MySQL軟件包的教程

 更新時(shí)間:2015年06月03日 10:03:33   作者:周振興  
這篇文章主要介紹了用Autoconf檢測(cè)MySQL軟件包的教程,主要使用編寫(xiě)好的ax_lib_mysql腳本進(jìn)行操作,需要的朋友可以參考下

在你的程序(或者工程)中,如果編譯階段需要檢測(cè)當(dāng)前環(huán)境中是否存在MySQL客戶端相關(guān)的庫(kù)文件時(shí),你可以使用Autoconf來(lái)幫你完成這個(gè)工作,輕盈、優(yōu)雅、無(wú)痛。閱讀本文需要了解簡(jiǎn)單GNU Autoconf使用。
1. 本文的目標(biāo)

目的:編譯時(shí),根據(jù)configure參數(shù)(如果有--with-mysql),選擇性編譯對(duì)應(yīng)的MySQL相關(guān)的功能。

實(shí)現(xiàn):使用已經(jīng)寫(xiě)好的m4腳本:ax_lib_mysql.m4
2. 如何利用Autoconf實(shí)現(xiàn)

大部分你想到的事情都已經(jīng)有人做過(guò)嘗試了。這件事情也不例外,Autoconf中有很多腳本和指令幫你做事情。這里,需要使用ax_lib_mysql.m4來(lái)幫助我們。先把該文件放到程序/工程目錄中,并在configure.ac中新增如下指令來(lái)檢測(cè)MySQL庫(kù)文件和版本:

復(fù)制代碼 代碼如下:
m4_include(ax_lib_mysql.m4)
AX_LIB_MYSQL()
AM_CONDITIONAL(BUILD_MYSQL_SUPPORT, test x$MYSQL_VERSION != x)

說(shuō)明:AX_LIB_MYSQL()設(shè)置了三個(gè)變量,可以在Makefile.am中直接使用,分別是MYSQL_CFLAGS、MYSQL_LDFLAGS、MYSQL_VERSION,另外還會(huì)在config.h中預(yù)定義宏HAVE_MYSQL;AM_CONDITIONAL(...)則會(huì)根據(jù)是否需要開(kāi)啟MySQL支持,來(lái)設(shè)置變量BUILD_MYSQL_SUPPORT,這個(gè)變量可以在Makefile.am中使用。

在程序源代碼中一般有兩種方式可以獲取HAVE_MYSQL宏的方式:一個(gè)是直接包含config.h;另一個(gè)是在你程序的CFLAGS中新增-DHAVE_MYSQL。(注意:有的變量是可以在Makefile.am中使用,有的則是可以在C源代碼中使用)
方法一:直接include config.h

Autoconf工具會(huì)將所有的預(yù)定義宏存放在config.h(默認(rèn)情況)中,并在編譯器選項(xiàng)中新增-DHAVE_CONFIG_H(通過(guò)@DEFS@)。因?yàn)槲募x_lib_mysql.m4中,包含了如下代碼(如果加上--with-mysql并且找到了對(duì)應(yīng)mysql_config,那么如下代碼生效):

復(fù)制代碼 代碼如下:
AC_DEFINE([HAVE_MYSQL], [1],
[Define to 1 if MySQL libraries are available])

所以,config.h中會(huì)有對(duì)應(yīng)的宏定義:

復(fù)制代碼 代碼如下:
/* Define to 1 if MySQL libraries are available */
#define HAVE_MYSQL 1

在你的源代碼中(一般是頭文件),新增如下代碼:

復(fù)制代碼 代碼如下:
#ifdef HAVE_CONFIG_H
#include >config.h<
#endif

這之后,就可以在你的源代碼中,使用#ifdef HAVE_MYSQL ... #endif這樣的寫(xiě)法了
方法二:編譯器選項(xiàng)新增-DHAVE_MYSQL

因?yàn)槲募x_lib_mysql.m4包含了變量定義MYSQL_CFLAGS/MYSQL_LDFLAGS/MYSQL_VERSION,所以,簡(jiǎn)單的可以在Makefile.am中,直接根據(jù)這些變量來(lái)新增gcc編譯參數(shù)。類似如下寫(xiě)法:
 

復(fù)制代碼 代碼如下:
if MYSQL_VERSION
XXX_CFLAGES= -DHAVE_MYSQL
endif

這之后,也可以在你的源代碼中,使用#ifdef HAVE_MYSQL ... #endif這樣的寫(xiě)法了

小結(jié):上面兩種方法一個(gè)需要修改Makefile.am、一個(gè)需要修改頭文件,可以根據(jù)個(gè)人喜好來(lái)決定怎么做。
3. 更多關(guān)于ax_lib_mysql.m4的使用
常見(jiàn)的configure寫(xiě)法

有了上面的設(shè)置,程序就可以通過(guò)如下的方式來(lái)確定是否將MySQL客戶端的支持編譯到源代碼中:
 

復(fù)制代碼 代碼如下:
./configure --with-mysql
...
./configure --with-mysql[=no|yes]
...
./configure --with-mysql[=/YOUR_ENV_PATH/mysql_config] #如果mysql_config不在當(dāng)前的$PATH中,則需要顯示指定。
...

如果對(duì)最低版本有要求

另外,如果你對(duì)MySQL版本有要求,例如,你希望只有檢測(cè)到5.5以上的MySQL客戶端,才編譯對(duì)MySQL的支持,則可以在configure.ac中這樣使用AX_LIB_MYSQL:
AX_LIB_MYSQL(5.5.18)
修改--with-mysql的默認(rèn)行為

這里意思是說(shuō),如果在configure中沒(méi)有--with-mysql選項(xiàng)時(shí),則編譯時(shí)不加上對(duì)MySQL的支持(如果寫(xiě)了),也就是說(shuō)如下兩種寫(xiě)法意思相同:
 

復(fù)制代碼 代碼如下:
./configure --with-mysql=no
./configure

ax_lib_mysql.m4的默認(rèn)行為并非如此,需要對(duì)其代碼做小小的修改:

 

復(fù)制代碼 代碼如下:
@@ -61,7 +61,7 @@
             MYSQL_CONFIG="$withval"
         fi
         ],
-        [want_mysql="yes"]
+        [want_mysql="no"]
     )
     AC_ARG_VAR([MYSQL_CONFIG], [Full path to mysql_config program])

這樣就如愿了。
4. 更一般的DEBUG選項(xiàng)

其實(shí)使用Autoconf這種用法更一般的是開(kāi)啟或者關(guān)閉DEBUG選項(xiàng)。這個(gè)實(shí)現(xiàn)會(huì)比上面簡(jiǎn)單很多。

目標(biāo):編譯時(shí),根據(jù)configure參數(shù)(如果有--enable-debug),則執(zhí)行程序中#ifdef DEBUG ... #endif。(經(jīng)常看到這樣的寫(xiě)法吧)

相比上面的--with-mysql這個(gè)就簡(jiǎn)單多了(沒(méi)有版本信息、不需要找mysql_config等),所以實(shí)現(xiàn)也簡(jiǎn)單多了,只需在你的configure.ac中新增如下代碼:

 

復(fù)制代碼 代碼如下:
AC_ARG_ENABLE(debug,
AS_HELP_STRING([--enable-debug],
               [enable debugging, default: no]),
[case "${enableval}" in
             yes) debug=true ;;
             no)  debug=false ;;
             *)   AC_MSG_ERROR([bad value ${enableval} for --enable-debug]) ;;
esac],
[debug=false])
AM_CONDITIONAL(DEBUG, test x"$debug" = x"true")

如果configure時(shí),帶有參數(shù)--enable-debug,則設(shè)置調(diào)用AM_CONDITIONAL設(shè)置遍歷DEBUG。這樣就可以在Makefile中根據(jù)遍歷DEBUG,來(lái)選擇性的新增編譯參數(shù)-DDEBUG,所以配套的還需要再M(fèi)akefile.am中新增:
 

復(fù)制代碼 代碼如下:
if DEBUG
XXX_CFALGS=... -DDEBUG
else
XXX_CFALGS=...
fi

這時(shí),你的代碼中就可以寫(xiě)#ifdef DEBUG ... #endif了。

另一種包含config.h的方法跟前面類似,只不過(guò)需要將AM_CONDITIONAL那里換成:
 

復(fù)制代碼 代碼如下:
if test x"$debug" = x"true"
AC_DEFINE([HAVE_MYSQL], [1],
[Define to 1 if MySQL libraries are available])
fi

那么程序代碼中include >config.h<就可以了。

  • 解決MySQL 8.0以上版本設(shè)置大小寫(xiě)不敏感的問(wèn)題

    解決MySQL 8.0以上版本設(shè)置大小寫(xiě)不敏感的問(wèn)題

    MySQL 8.0以上版本默認(rèn)區(qū)分大小寫(xiě),但在低版本(如5.7)中,可以通過(guò)在my.cnf配置文件的[mysqld]節(jié)下添加lower_case_table_names=1來(lái)設(shè)置大小寫(xiě)不敏感,本篇博客將介紹如何解決MySQL 8.0以上版本設(shè)置大小寫(xiě)不敏感的問(wèn)題,需要的朋友可以參考下
    2023-11-11
  • mysql慢查詢操作實(shí)例分析【開(kāi)啟、測(cè)試、確認(rèn)等】

    mysql慢查詢操作實(shí)例分析【開(kāi)啟、測(cè)試、確認(rèn)等】

    這篇文章主要介紹了mysql慢查詢操作,結(jié)合實(shí)例形式分析了mysql慢查詢操作中的開(kāi)啟、測(cè)試、確認(rèn)等實(shí)現(xiàn)方法及相關(guān)操作技巧,需要的朋友可以參考下
    2019-12-12
  • MySQL日期格式以及日期函數(shù)舉例詳解

    MySQL日期格式以及日期函數(shù)舉例詳解

    這篇文章主要給大家介紹了關(guān)于MySQL日期格式及日期函數(shù)的相關(guān)資料,日期在數(shù)據(jù)庫(kù)中是一個(gè)常見(jiàn)且重要的數(shù)據(jù)類型,在MySQL中我們可以使用各種函數(shù)和格式化選項(xiàng)來(lái)處理和顯示日期,需要的朋友可以參考下
    2023-11-11
  • 淺談mysql中concat函數(shù),mysql在字段前/后增加字符串

    淺談mysql中concat函數(shù),mysql在字段前/后增加字符串

    下面小編就為大家?guī)?lái)一篇淺談mysql中concat函數(shù),mysql在字段前/后增加字符串。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • MySQL表內(nèi)連和外連的具體使用

    MySQL表內(nèi)連和外連的具體使用

    我們?cè)谑褂肕ySQL的時(shí)候,經(jīng)常涉及到內(nèi)連接和外連接的應(yīng)用,本文就來(lái)詳細(xì)的介紹一下MySQL表內(nèi)連和外連的具體使用,感興趣的可以了解一下
    2023-10-10
  • CentOS7.5 安裝 Mysql8.0.19的教程圖文詳解

    CentOS7.5 安裝 Mysql8.0.19的教程圖文詳解

    這篇文章主要介紹了CentOS7.5 安裝 Mysql8.0.19的教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • mysql4.0升級(jí)到mysql5(4.1),解決字符集問(wèn)題

    mysql4.0升級(jí)到mysql5(4.1),解決字符集問(wèn)題

    軟件升級(jí)部分就不說(shuō)了,光說(shuō)數(shù)據(jù)庫(kù)遷移。
    2009-09-09
  • MYSQL開(kāi)發(fā)性能研究之批量插入數(shù)據(jù)的優(yōu)化方法

    MYSQL開(kāi)發(fā)性能研究之批量插入數(shù)據(jù)的優(yōu)化方法

    在網(wǎng)上也看到過(guò)另外的幾種方法,比如說(shuō)預(yù)處理SQL,比如說(shuō)批量提交。那么這些方法的性能到底如何?本文就會(huì)對(duì)這些方法做一個(gè)比較
    2017-07-07
  • Mysql刪除重復(fù)數(shù)據(jù)通用SQL的兩種方法

    Mysql刪除重復(fù)數(shù)據(jù)通用SQL的兩種方法

    本文主要介紹了Mysql刪除重復(fù)數(shù)據(jù)通用SQL的兩種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • 最新評(píng)論