C语言对mysql数据库的操作
生活随笔
收集整理的這篇文章主要介紹了
C语言对mysql数据库的操作
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
C語言對mysql數據庫的操作 原文:C語言對mysql數據庫的操作
????? ?char user[32]=”username”;??
?????? char passwd[32]=”pwd”;?
?????? char dbname[32]=”testdb”;? 4.數據庫操作 1).初始化數據庫:
??????? mysql_init(&mysql);
???????2).連接數據庫:
????????? ?mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0);
???????? 我們在操作時,可以對以上的函數進行if測試,如果初始化或者連接出錯,作出相應提示,以便調試。
5.對數據庫的操作:
???????? Mysql_query(&mysql, “select * from testdb where condition”);
???????? 我們在實際操作中,為了更方便的使用程序中的某些變量,我們將會用到一個函數:
???????? int sprintf(char *str, const char *format, …);
???????? 這個函數用來格式化我們的字符串,然后將變量按照給你的格式,賦給第一個參數。
???????? 我們使用這個方法方法可以很方便的使用我們的變量來對數據庫進行操作。例如我們將要進行數據庫的查詢操作,我們就可以這樣使用:
???????? sprintf(sql,”select * from testdb where username = ‘%s’”, u_name);
???????? 然后使用mysql_query(&mysql, sql)進行查詢。
????????
???????? 其實大家已經注意到了,在sprintf函數中第二個參數是我們非常熟悉的sql語句,只不過在條件的右端使用了類似輸出函數的格式符,因為我們使用了變 量。當然,在沒有變量的時候,我們可以省去第三個參數,但是這樣,我們使用sprintf的作用也就隨之消失了。?
??????? 大家對sql語句的操作一定比我更加熟悉,因此,關于刪除和修改的例子我們就不過列舉了。
6.關閉數據庫連接:????????
??? ?Mysql_close(&mysql);???????? 也許大伙都使用過php對mysql進行操作。也許也已經發現,在c語言中,對mysql數據庫的操作和php有很大的相似之處。 下面我賦上一段小小的代碼,來結束這篇文檔!:)希望大家給予指點。 #include <stdio.h>
#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;? sprintf(sql,”select * from testdb where user_name = ‘%s’”, u_name);
???????? 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;}? 7.編譯: 別忘了加上庫位置,否則編譯無法通過! gcc? -L/usr/lib/mysql –lmysqlclient func.c -o func 呵呵,別忘記哦! posted on 2014-12-09 08:46 NET未來之路 閱讀(...) 評論(...) 編輯 收藏
這已經是一相當老的話題。不過今天我才首次使用,把今天的一些體會寫下來,也許能給一些新手帶來一定的幫助,更重要的是供自己今后忘記的怎么使用而進行查閱的!
我們言歸正傳 1.頭文件: #include <stdio.h> #include <stdlib.h> #include <mysql/mysql.h> //這個是必需要包含的,下面對mysql的所有操作函數,都出自這里 2.定義一個MYSQL變量: MYSQL mysql; 這里MYSQL是一個用于連接MySql數據庫的變量。 在后面對mysql數據庫的操作中,我們就用這個MYSQL變量作為句柄的。 3.定義數據庫參數: char host[32]=”localhost”;??????? ?char user[32]=”username”;??
?????? char passwd[32]=”pwd”;?
?????? char dbname[32]=”testdb”;? 4.數據庫操作 1).初始化數據庫:
??????? mysql_init(&mysql);
???????2).連接數據庫:
????????? ?mysql_real_connect(&mysql,host,user,passwd,dbname,0,NULL,0);
???????? 我們在操作時,可以對以上的函數進行if測試,如果初始化或者連接出錯,作出相應提示,以便調試。
5.對數據庫的操作:
???????? Mysql_query(&mysql, “select * from testdb where condition”);
???????? 我們在實際操作中,為了更方便的使用程序中的某些變量,我們將會用到一個函數:
???????? int sprintf(char *str, const char *format, …);
???????? 這個函數用來格式化我們的字符串,然后將變量按照給你的格式,賦給第一個參數。
???????? 我們使用這個方法方法可以很方便的使用我們的變量來對數據庫進行操作。例如我們將要進行數據庫的查詢操作,我們就可以這樣使用:
???????? sprintf(sql,”select * from testdb where username = ‘%s’”, u_name);
???????? 然后使用mysql_query(&mysql, sql)進行查詢。
????????
???????? 其實大家已經注意到了,在sprintf函數中第二個參數是我們非常熟悉的sql語句,只不過在條件的右端使用了類似輸出函數的格式符,因為我們使用了變 量。當然,在沒有變量的時候,我們可以省去第三個參數,但是這樣,我們使用sprintf的作用也就隨之消失了。?
??????? 大家對sql語句的操作一定比我更加熟悉,因此,關于刪除和修改的例子我們就不過列舉了。
6.關閉數據庫連接:????????
??? ?Mysql_close(&mysql);???????? 也許大伙都使用過php對mysql進行操作。也許也已經發現,在c語言中,對mysql數據庫的操作和php有很大的相似之處。 下面我賦上一段小小的代碼,來結束這篇文檔!:)希望大家給予指點。 #include <stdio.h>
#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;? sprintf(sql,”select * from testdb where user_name = ‘%s’”, u_name);
???????? 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;}? 7.編譯: 別忘了加上庫位置,否則編譯無法通過! gcc? -L/usr/lib/mysql –lmysqlclient func.c -o func 呵呵,別忘記哦! posted on 2014-12-09 08:46 NET未來之路 閱讀(...) 評論(...) 編輯 收藏
轉載于:https://www.cnblogs.com/lonelyxmas/p/4152404.html
總結
以上是生活随笔為你收集整理的C语言对mysql数据库的操作的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 为何蜘蛛侠还能拍续集
- 下一篇: 微信网名好听