您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)如何使用Lccwin32進(jìn)行MySQL開發(fā)的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
我將通過一個(gè)簡單的例子演示如何通過Lccwin32進(jìn)行MYSQL的開發(fā)。重點(diǎn)的地
方不是代碼部分,而是編譯器的配置lccwin32本身的ide編輯器部分對中文的
支持等于0,并且在頭文件引用路徑設(shè)置上存在bug,我們要手工處理!這也是
我認(rèn)為寫這篇筆記的重要性。
剛才提到了lccwin32編輯器有bug,我們需要手工修改編譯器產(chǎn)生的makefile
文件否則根本無法編譯。
假設(shè)你是采用默認(rèn)路徑,則lccwin32編輯器自動產(chǎn)生的makefile文件中應(yīng)該包
含類似子段:
CFLAGS=-I"c:lccinclude" -O -p6 -unused -ansic
我們?nèi)绻苯訌木庉嬈魈砑佣囝^文件引用路徑會產(chǎn)生錯(cuò)誤,因此我們手工添加
路徑變成下邊這種形式:
CFLAGS=-I"c:lccinclude" -I"c:mysqlinclude" -O -p6 -unused -ansic
ok!第一個(gè)問題頭文件引用解決了。
現(xiàn)在我們開始解決下一個(gè)問題庫文件(.lib)。windows的mysql庫文件采用vc5編
譯,我們要先利用lccwin32附帶的庫轉(zhuǎn)換工具進(jìn)行轉(zhuǎn)化。轉(zhuǎn)換之后lccwin32就可
以正常識別此庫文件。那么重要的問題是我們?nèi)绾我霂煳募ccwin32中我們
可以使用兩種方法,第一種方法就是從編輯器的庫引用中直接敲入庫名稱;另外
一種就是利用編譯器的預(yù)處理器偽指令#pragma lib "庫"。我推薦采用第二種,
因?yàn)殚_發(fā)過程中我們需要debug版庫文件進(jìn)行debuger,實(shí)際發(fā)行中為了效率我們
則需要用opt版生成最終發(fā)行文件,在lccwin32這套環(huán)境中直接在編輯器中進(jìn)行設(shè)
置是不明智的!
現(xiàn)在我們解決了頭文件和庫文件的引用,實(shí)際上已經(jīng)沒有什么問題。一個(gè)簡簡單
單的例子如下:
#pragma lib
#include
#include "mysql.h"
MYSQL *myData;
int main(int argc, char *argv[])
{
char userid[20];
strcpy(userid, "root"); // 賬號
char password[20];
strcpy(password, ""); // 密碼
char host[20];
strcpy(host, "localhost"); // 主機(jī)
char dbName[10];
strcpy(dbName, "test"); // 數(shù)據(jù)庫
if ( (myData = mysql_init((MYSQL*) 0)) &&
mysql_real_connect(myData, host, userid, password, dbName, MYSQL_PORT, NULL, 0))
printf("Mysql readyn");
else
exit(0);
mysql_close( myData ) ;
return 1;
}
如果完全依照本文,已經(jīng)產(chǎn)生一個(gè)3.03kb或13.03kb(debuger)的可以執(zhí)行文件。順便說,
我不知道現(xiàn)在還有比拼產(chǎn)生的可執(zhí)行文件體積不。mysql官方例程用lccwin32編譯后體積
只有vc產(chǎn)生的可執(zhí)行文件大小的1/5!
感謝各位的閱讀!關(guān)于“如何使用Lccwin32進(jìn)行MySQL開發(fā)”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。