【Linux】Ubuntu下C語言訪問MySQL資料庫入門

来源:http://www.cnblogs.com/iihcy/archive/2016/01/06/5106365.html
-Advertisement-
Play Games

使用的系統是Ubuntu 11.10.資料庫是MySQL。MySQL資料庫環境配置首先需要安裝MySQL客戶端和伺服器,命令行安裝方式為:[cpp]view plaincopyprint?sudoapt-getinstallmysql-servermysql-client然後,要使用C語言編程訪問數...


使用的系統是Ubuntu 11.10.資料庫是MySQL。

 

MySQL資料庫環境配置

 

首先需要安裝MySQL客戶端和伺服器,命令行安裝方式為:

 

[cpp] view plaincopyprint?  
  1. sudo apt-get install mysql-server mysql-client  


然後,要使用C語言編程訪問資料庫,需要另外安裝一個開發包:

 

 

[cpp] view plaincopyprint?  
  1. sudo apt-get install libmysqlclient15-dev  

 

 

在MySQL中建立相應資料庫

首先以用戶rick登錄MySQL資料庫(用戶rick已經被root許可權用戶賦予了創建資料庫等等的許可權):

然後創建一個名為foo的資料庫:

 

[cpp] view plaincopyprint?  
  1. CREATE DATABASE foo;  

然後利用如下SQL語句創建表及插入數據:

 

 

[cpp] view plaincopyprint?  
  1. CREATE TABLE children(  
  2.     childno int(11) NOT NULL auto_increment,  
  3.     fname varchar(30),  
  4.     age int(11),  
  5.     PRIMARY KEY (childno)  
  6.     );  
  7.   
  8. INSERT INTO children(childno,fname,age) VALUES(1,'Jenny',21);  
  9. INSERT INTO children(childno,fname,age) VALUES(2,'Andrew',17);  
  10. INSERT INTO children(childno,fname,age) VALUES(3,'Gavin',8);  
  11. INSERT INTO children(childno,fname,age) VALUES(4,'Duncan',6);  
  12. INSERT INTO children(childno,fname,age) VALUES(5,'Emma',4);  
  13. INSERT INTO children(childno,fname,age) VALUES(6,'Alex',15);  
  14. INSERT INTO children(childno,fname,age) VALUES(7,'Adrian',9);  


在MySQL命令行模式中執行方法如下:

 

 

MySQL資料庫連接測試

 

然後採用如下C語言進行資料庫連接測試connect1.c:

 

[cpp] view plaincopyprint?  
  1. #include <stdlib.h>  
  2. #include <stdio.h>  
  3.   
  4. #include "mysql.h"  
  5.   
  6. int main(int argc,char *argv[])  
  7. {  
  8.   MYSQL *conn_ptr;  
  9.   conn_ptr = mysql_init(NULL);  
  10.   
  11.   if(!conn_ptr)  
  12.   {  
  13.     fprintf(stderr,"mysql_init failed\n");  
  14.     return EXIT_FAILURE;  
  15.   }  
  16.   
  17.   conn_ptr = mysql_real_connect(conn_ptr,"localhost","rick","rick","foo",0,NULL,0);  
  18.   
  19.   if(conn_ptr)  
  20.     printf("Connection success\n");  
  21.   else  
  22.     printf("Connection failed\n");  
  23.   
  24.   mysql_close(conn_ptr);  
  25.   
  26.   return EXIT_SUCCESS;  
  27. }  

執行結果:

 

註意的是:需要指定include庫和庫文件的路徑名,以及指定鏈接的庫模塊mysqlclient。

如果不在開始的時候安裝開發包,就會產生如下錯誤:

 

執行SQL語句進行數據操作

向資料庫表children中插入一行:

 

[cpp] view plaincopyprint?  
  1. #include <stdlib.h>  
  2. #include <stdio.h>  
  3.   
  4. #include "mysql.h"  
  5.   
  6. int main()  
  7. {  
  8.   MYSQL my_connecyion;  
  9.   int res;  
  10.   
  11.   mysql_init(&my_connecyion);  
  12.   
  13.   if(mysql_real_connect(&my_connecyion,"localhost","rick","rick","foo",0,NULL,0))  
  14.   {  
  15.     printf("Connection success\n");  
  16.   
  17.     //執行SQL語句  
  18.     res = mysql_query(&my_connecyion,"INSERT INTO children(fname,age) VALUES('Ann',3)");  
  19.   
  20.     if(!res)  
  21.       printf("Inserted %lu rows\n",(unsigned long)mysql_affected_rows(&my_connecyion));  
  22.     else  
  23.       fprintf(stderr,"Insert error %d : %s \n",mysql_errno(&my_connecyion),mysql_error(&my_connecyion));  
  24.   
  25.     mysql_close(&my_connecyion);  
  26.   }  
  27.   else{  
  28.     fprintf(stderr,"Connection failed\n");  
  29.     if(mysql_errno(&my_connecyion))  
  30.       fprintf(stderr,"Connection error %d : %s\n",mysql_errno(&my_connecyion),mysql_error(&my_connecyion));  
  31.   }  
  32.   
  33.   return EXIT_SUCCESS;  
  34. }  


運行結果:

 

 

在這裡特別需要註意的是:

函數mysql_affected_rows返回的是被一個更新操作修改的行數,而不是滿足where子句的行數。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 2.1、maven父子模塊在實際開發中,我們基本都會用maven父子分模塊的方式進行項目的開發。2.2、實際操作2.2.1、手工建立一個ssmm0的文件夾,併在該文件夾中加入一個pom.xml文件,該pom.xml文件內容如下: 1 2 4 5 4.0.0 6 7 com.x...
  • 外面沙塵滾滾一直向北去了,意識到年關到了,碼農們都回鄉過年去了,而我卻留在這裡玩弄“拉鏈”。不要想歪了,我說的不是褲襠拉鏈而是scalaz Zipper,一種泛函數據結構游標(cursor)。在函數式編程模式里的集合通常是不可變的(immutable collection),我們會發現在FP編程過....
  • ThreadLocal是線程局部變數,其中保存了特定於該線程的值.每個線程都擁有一份獨立的副本值,即每個線程修改變數值不影響其他線程該變數的副本值.這些特定於線程的值保存在Thread對象中,當線程終止後,這些值會作為垃圾回收. 如果沒有看源碼可能會認為ThreadLocal內部的實現方式應該是採用...
  • 一、簡介 GPS(全球定位系統)接收機與手持機之間的數據交換格式一般都由生產廠商預設定製,其定義內容普通用戶很難知曉,且不同品牌、不同型號的GPS接收機所配置的控制應用程式也因生產廠家的不同而不同。所以,對於通用GPS應用軟體,需要一個統一格式的數據標準,以解決與任意一臺GPS的介面問題。NMEA-...
  • 一、簡介 OpenGL™ 是行業領域中最為廣泛接納的 2D/3D 圖形 API, 其自誕生至今已催生了各種電腦平臺及設備上的數千優秀應用程式。OpenGL™ 是獨立於視窗操作系統或其它操作系統的,亦是網路透明的。在包含CAD、內容創作、能源、娛樂、游戲開發、製造業、製藥業及虛擬現實等行業領域中,O...
  • Background ProcessingRZ01Job Scheduling MonitorSM36Schedule Background JobSM36WIZJob definition wizardSM37Overview of job selectionSM37BSimple version...
  • IOC:Inversion of Control(控制反轉)。IOC它所體現的並不是一種技術,而是一種思想,一種將設計好的對象交給容器來管理的思想。IOC的核心思想就體現在控制、反轉這兩個詞上面,要理解就必須要理解幾個問題: 1、誰控制誰?在傳統的開發工作中,我們一般都是主動去new一個對象,這個是...
  • 每一種語言都有相應的關鍵詞,每個關鍵詞都有他獨特的作用,來看看swfit中的關鍵詞:關鍵詞:用來聲明的:class, deinit, enum, extension, func, import, init, let, protocol, static, struct, subscript, type...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...