c怎么操作mysql 手機(jī)圈存etc怎么操作

C語(yǔ)言怎樣連接mysql數(shù)據(jù)庫(kù)

mysql是有c語(yǔ)言接口的,安裝相應(yīng)庫(kù)后就可以鏈接了,一般連接mysql的函數(shù)是mysql_connect或者mysql_real_connect(大概就是這么拼的吧。。。)可以使用mysql_query執(zhí)行sql語(yǔ)句

在彌勒等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè) 網(wǎng)站設(shè)計(jì)制作按需求定制設(shè)計(jì),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計(jì),網(wǎng)絡(luò)營(yíng)銷推廣,成都外貿(mào)網(wǎng)站建設(shè)公司,彌勒網(wǎng)站建設(shè)費(fèi)用合理。

如何用C語(yǔ)言連接MYSQL數(shù)據(jù)庫(kù)

1、配置ODBC數(shù)據(jù)源。

2、使用SQL函數(shù)進(jìn)行連接。

對(duì)于1、配置數(shù)據(jù)源,配置完以后就可以編程操作數(shù)據(jù)庫(kù)了。

對(duì)于2、使用SQL函數(shù)進(jìn)行連接,參考代碼如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

#includewindows.h

#includesql.h

#includesqlext.h

void

main()

{

HENV

henv;

//環(huán)境句柄

HDBC

hdbc;

//數(shù)據(jù)源句柄

HSTMT

hstmt;

//執(zhí)行語(yǔ)句句柄

unsigned

char

datasource[]="數(shù)據(jù)源名稱";

//即源中設(shè)置的源名稱

unsigned

char

user[]=

"用戶名";

//數(shù)據(jù)庫(kù)的帳戶名

unsigned

char

pwd[]=

"密碼";

//數(shù)據(jù)庫(kù)的密碼

unsigned

char

search[]="select

xm

from

stu

where

xh=0";

SQLRETURN

retcode;

//記錄各SQL函數(shù)的返回情況

//

分配環(huán)境句柄

retcode=

SQLAllocEnv(henv);

//

等介于

SQLAllocHandle(SQL_HANDLE_ENV,

SQL_NULL

,

henv);

//

設(shè)置ODBC環(huán)境版本號(hào)為3.0

retcode=

SQLSetEnvAttr(henv,

SQL_ATTR_ODBC_VERSION,

(void*)SQL_OV_ODBC3,

0);

//

分配連接句柄

retcode=

SQLAllocConnect(henv,hdbc);

//

等介于

SQLAllocHandle(SQL_HANDLE_DBC,

henv,

hdbc);

//設(shè)置連接屬性,登錄超時(shí)為*rgbValue秒(可以沒有)

//

SQLSetConnectAttr(hdbc,

SQL_LOGIN_TIMEOUT,

(SQLPOINTER)(rgbValue),

0);

//直接連接數(shù)據(jù)源

//

如果是windows身份驗(yàn)證,第二、三參數(shù)可以是

用C語(yǔ)言如何對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行操作

有時(shí)為了性能,我們會(huì)直接用C語(yǔ)言來(lái)開發(fā)相關(guān)的模塊,尤其在我們的web應(yīng)用中,雖然PHP、JSP等腳本均提供了MySQL的接口,但是顯然直接使用C語(yǔ)言具有更好的安全性和性能,Michael以前用PHP開發(fā)的多個(gè)項(xiàng)目中就使用了C語(yǔ)言編寫的這類接口,然后再編譯到php里面,供php腳本直接使用,這方面的話題就不多說(shuō)了,下面主要說(shuō)一下在Linux下如何用C語(yǔ)言連接MySQL數(shù)據(jù)庫(kù),并且讀取里面的數(shù)據(jù)返回,同時(shí)如何進(jìn)行編譯。 if defined(_WIN32) || defined(_WIN64)為了支持windows平臺(tái)上的編譯#includewindows.h#endif#includestdio.h#includestdlib.h #includemysql.h 我的機(jī)器上該文件在/usr/local/include/mysql下 定義MySQL數(shù)據(jù)庫(kù)操作的宏,也可以不定義留著后面直接寫進(jìn)代碼 defineSELECT_QUERYselectusernamefromtbb_userwhereuserid=%dintmain(intargc,char**argv)char**argv相當(dāng)于char*argv[]{MYSQL mysql,*sock;定義數(shù)據(jù)庫(kù)連接的句柄,它被用于幾乎所有的MySQL函數(shù) MYSQL_RES *res;查詢結(jié)果集,結(jié)構(gòu)類型 MYSQL_FIELD *fd ;包含字段信息的結(jié)構(gòu) MYSQL_ROW row ;存放一行查詢結(jié)果的字符串?dāng)?shù)組 char qbuf[160];存放查詢sql語(yǔ)句字符串 if(argc!=2){//檢查輸入?yún)?shù) fprintf(stderr,usage:mysql_selectuserid\n\n);exit(1);}mysql_init(mysql);if(!(sock=mysql_real_connect (mysql,localhost,dbuser,dbpwd,9tmd_bbs_utf8,0,NULL,0))){ fprintf(stderr,Couldn'tconnecttoengine!\n%s\n\n,mysql_error(mysql));perror();exit(1);}sprintf(qbuf,SELECT_QUERY,atoi(argv[1])); if(mysql_query(sock,qbuf)){ fprintf(stderr,Queryfailed(%s)\n,mysql_error(sock));exit(1);}if(!(res=mysql_store_result(sock))){fprintf(stderr,Couldn'tgetresultfrom%s\n,mysql_error(sock));exit(1);}printf(numberoffieldsreturned:%d\n,mysql_num_fields(res));while(row=mysql_fetch_row(res)){printf(Theruserid#%d'susernameis:%s\n,atoi(argv[1]),(((row[0]==NULL)(!strlen(row[0])))?NULL:row[0])); puts(queryok!\n);}mysql_free_result(res); mysql_close(sock);exit(0);return0;為了兼容大部分的編譯器加入此行} 編譯的時(shí)候,使用下面的命令 gcc -o mysql_select ./mysql_select.c -I/usr/local/include/mysql -L/usr/local/lib/mysql -lmysqlclient (-lz) (-lm) 后面兩個(gè)選項(xiàng)可選,根據(jù)您的環(huán)境情況運(yùn)行的時(shí)候,執(zhí)行下面的命令 ./mysql_select 1 將返回如下結(jié)果: numberoffieldsreturned:1 Theruserid#1'susernameis:Michaelqueryok!上面的代碼我想大部分都能看明白,不明白的可以參考一下MySQL提供的有關(guān)C語(yǔ)言API部分文檔源碼天空 ,各個(gè)函數(shù)都有詳細(xì)說(shuō)明,有時(shí)間我整理一份常用的API說(shuō)明出來(lái)。

分享題目:c怎么操作mysql 手機(jī)圈存etc怎么操作
鏈接URL:http://muchs.cn/article38/doeespp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、虛擬主機(jī)、網(wǎng)站設(shè)計(jì)、定制開發(fā)網(wǎng)站營(yíng)銷、標(biāo)簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)