這已經(jīng)是一相當(dāng)老的話題。不過(guò)今天我才首次使用,把今天的一些體會(huì)寫(xiě)下來(lái),也許能給一些新手帶來(lái)一定的幫助,更重要的是供自己今后忘記的怎么使用而進(jìn)行查閱的!
????? ?char user[32]=”username”;??
?????? char passwd[32]=”pwd”;?
?????? char dbname[32]=”testdb”;?
??????? mysql_init(&mysql);
???????2).連接數(shù)據(jù)庫(kù):
????????? ?mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0);
???????? 我們?cè)诓僮鲿r(shí),可以對(duì)以上的函數(shù)進(jìn)行if測(cè)試,如果初始化或者連接出錯(cuò),作出相應(yīng)提示,以便調(diào)試。
5.對(duì)數(shù)據(jù)庫(kù)的操作:
???????? Mysql_query(&mysql, “select * from testdb where condition”);
???????? 我們?cè)趯?shí)際操作中,為了更方便的使用程序中的某些變量,我們將會(huì)用到一個(gè)函數(shù):
???????? int sprintf(char *str, const char *format, …);
???????? 這個(gè)函數(shù)用來(lái)格式化我們的字符串,然后將變量按照給你的格式,賦給第一個(gè)參數(shù)。
???????? 我們使用這個(gè)方法方法可以很方便的使用我們的變量來(lái)對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作。例如我們將要進(jìn)行數(shù)據(jù)庫(kù)的查詢操作,我們就可以這樣使用:
???????? sprintf(sql,”select * from testdb where username = ‘%s’”, u_name);
???????? 然后使用mysql_query(&mysql, sql)進(jìn)行查詢。
????????
???????? 其實(shí)大家已經(jīng)注意到了,在sprintf函數(shù)中第二個(gè)參數(shù)是我們非常熟悉的sql語(yǔ)句,只不過(guò)在條件的右端使用了類似輸出函數(shù)的格式符,因?yàn)槲覀兪褂昧俗?量。當(dāng)然,在沒(méi)有變量的時(shí)候,我們可以省去第三個(gè)參數(shù),但是這樣,我們使用sprintf的作用也就隨之消失了。?
??????? 大家對(duì)sql語(yǔ)句的操作一定比我更加熟悉,因此,關(guān)于刪除和修改的例子我們就不過(guò)列舉了。
6.關(guān)閉數(shù)據(jù)庫(kù)連接:????????
??? ?Mysql_close(&mysql);????????
#include <mysql/mysql.h>
#include <stdlib.h>
#include <errno.h>
#include <syslog.h>
MYSQL mysql;
main(){???
???????? char host[32]=”localhost”; // mysql host
???????? char user[32]=”username”;//mysql user name
???????? char passwd[32]="pwd";??????? //mysql pwd
???????? char dbname[32]=”testdb”;//mysql db
??????? ?
??????? ?
??????? ??
?????? if( mysql_init(&mysql) == NULL )
???????? {??
???????????????? syslog(LOG_USER|LOG_INFO,”inital mysql handle error\n”);
???????? ???????? return 1;?
??????? }
???????? if (mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0) == NULL)
???????? {
?????????????????? syslog(LOG_USER|LOG_INFO, “Failed to connect to database: Error: %s\n”,mysql_error(&mysql));
???????? ???????? return 1;?
??????? }
????????else syslog(LOG_USER|LOG_INFO, “connect to database: \n”);
????????printf(”connected to the db!\n”);?
??????? int a = find_ps();?
??????? printf(”the num is:%d\n”,a);?
??????? db_close();?
??????? return 0;}int db_close(){
??????? mysql_close(&mysql);
????????return 0;
?????? }
????? int? find_ps (){
???????? MYSQL_ROW m_row;
???????? MYSQL_RES *m_res;
???????? char sql[1024],username[32];
???????? int res=1;
???????? int *id;?
???????? if(mysql_query(&mysql,sql) != 0)
???????? {
?????????????????? syslog(LOG_USER|LOG_INFO, “select ps_info Error: %s\n”,mysql_error(&mysql));???????
?? ?????? ???????? return res;????????
???????? }????????
??????? ?m_res = mysql_store_result(&mysql);
???????? if(m_res==NULL)
???????? {
?????????????????? syslog(LOG_USER|LOG_INFO, “select username Error: %s\n”,mysql_error(&mysql));?
??? ?????????????? res = 3;
?????????????????? return res;
???????? }
???????? }
???????? mysql_free_result(m_res);
???????? return res;}?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
