C語言連接數據庫

一、準備工作

在使用C語言連接數據庫進行編程之前,需要先進行以下準備工作:

1、安裝相應數據庫的驅動程序和連接庫。

#include<mysql/mysql.h>

2、連接數據庫需要相關的頭文件及庫文件

在Windows下,需要在工程里添加 libmysql.dll 庫文件,在Linux下,則需要在編譯時添加 libmysqlclient 庫文件

gcc test.c -lmysqlclient

二、連接數據庫

連接數據庫的基本操作如下:

1、定義連接變量

MYSQL mysql;

2、初始化數據庫連接

mysql_init(&mysql);

3、連接數據庫

if(mysql_real_connect(&mysql,"localhost","root","password","test",0,NULL,0))
{
   printf("Connection success!");
}
else
{
   printf("Connection fail!");
}

三、執行SQL語句

對數據庫進行操作,就需要執行相應的SQL語句。執行SQL語句的基本操作如下:

1、定義SQL語句變量

char *sql = "insert into student(id,name)values(1,'Tom')";

2、執行SQL語句

if(mysql_query(&mysql,sql))
{
    printf("Execute SQL fail!");
}
else
{
    printf("Execute SQL success!");
}

四、獲取結果

執行完SQL語句後需要獲取查詢結果,獲取結果的基本操作如下:

1、定義存儲結果的結構體

MYSQL_RES *result;

2、獲取結果

result = mysql_use_result(&mysql);

3、處理結果

MYSQL_ROW row;
while((row = mysql_fetch_row(result)))
{
    printf("%s\t%s\t%s\t%s\n",row[0],row[1],row[2],row[3]);
}
mysql_free_result(result);

五、斷開連接

操作完數據庫後需要斷開連接,斷開連接的基本操作如下:

mysql_close(&mysql);

六、完整代碼示例

#include<stdio.h>
#include<mysql/mysql.h>

int main()
{
    MYSQL mysql;
    mysql_init(&mysql);
    if(mysql_real_connect(&mysql,"localhost","root","password","test",0,NULL,0))
    {
        printf("Connection success!\n");
        char *sql = "insert into student(id,name)values(1,'Tom')";
        if(mysql_query(&mysql,sql))
        {
            printf("Execute SQL fail!\n");
        }
        else
        {
            printf("Execute SQL success!\n");
        }
        MYSQL_RES *result;
        result = mysql_use_result(&mysql);
        MYSQL_ROW row;
        while((row = mysql_fetch_row(result)))
        {
            printf("%s\t%s\t%s\t%s\n",row[0],row[1],row[2],row[3]);
        }
        mysql_free_result(result);
        mysql_close(&mysql);
    }
    else
    {
        printf("Connection fail!\n");
    }
    return 0;
}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/219984.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-09 11:02
下一篇 2024-12-09 11:02

相關推薦

  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28
  • Python語言實現人名最多數統計

    本文將從幾個方面詳細介紹Python語言實現人名最多數統計的方法和應用。 一、Python實現人名最多數統計的基礎 1、首先,我們需要了解Python語言的一些基礎知識,如列表、字…

    編程 2025-04-28
  • Python作為中心語言,在編程中取代C語言的優勢和挑戰

    Python一直以其簡單易懂的語法和高效的編碼環境而著名。然而,它最近的發展趨勢表明Python的使用範圍已經從腳本語言擴展到了從Web應用到機器學習等廣泛的開發領域。與此同時,C…

    編程 2025-04-28
  • Python基礎語言

    Python作為一種高級編程語言擁有簡潔優雅的語法。在本文中,我們將從多個方面探究Python基礎語言的特點以及使用技巧。 一、數據類型 Python基礎數據類型包括整數、浮點數、…

    編程 2025-04-28

發表回復

登錄後才能評論