MySQL的C++簡單封裝

来源:http://www.cnblogs.com/mreo/archive/2016/04/02/MrEO.html
-Advertisement-
Play Games

頭文件 my_sql.h 實現文件 my_sql.cpp 調用實例 main.cpp ...


/*
*介紹:MySQL的簡單封裝,支持流操作輸入輸出MySQL語句,然而並沒有什麼軟用,大二學生自娛自樂,有不足求指點
*作者:MrEO
*日期:2016.3.26
*/

 

頭文件 my_sql.h

 1 #ifndef MY_SQL_H
 2 #define MY_SQL_H
 3 
 4 #include <mysql.h>
 5 #include <iostream>
 6 #include <string>
 7 #include <iomanip>
 8 
 9 class My_sql
10 {
11     public:
12         My_sql();                     //初始化API、初始化結構、設置字元集、連接資料庫 
13         ~My_sql();                     //釋放記憶體、關閉伺服器連接、結束伺服器庫、結束API庫 
14         unsigned row_count();         //返回集中的行數 
15         unsigned field_count();        //返回集中的列數 
16         friend std::ostream & operator <<(std::ostream &out, My_sql &sql);
17      //通過std::ostream輸出列名、結果集 
18         friend std::istream & operator >>(std::istream &in, My_sql &sql);
19      //通過std::istream輸入執行SQL語句,並保存結果集地址至成員變數result 
20 //      friend My_sql & operator >>(const std::string &q, My_sql &sql);
21      //通過std::string輸入執行SQL語句 ,並保存結果集地址至成員變數result
22         friend My_sql & operator <<(My_sql &sql, const std::string &q);
23      //通過std::string輸入執行SQL語句 ,並保存結果集地址至成員變數result
24 
25     protected:
26         bool query(const std::string &q);         //執行SQL語句,保存完整的結果集地址至成員變數result
27         My_sql & display_field_name(std::ostream &out = std::cout, int setw_n = 16);    //輸出列名 
28         My_sql & display_result(std::ostream &out = std::cout, int setw_n = 16);        //輸出結果集 
29         MYSQL mysql;                      //對象 
30         MYSQL_RES *result = NULL;         //結果集 
31         MYSQL_FIELD *field = NULL;        //
32         MYSQL_ROW row;                    //
33 };
34 
35 #endif

 

 

實現文件 my_sql.cpp

 1 #include "my_sql.h"
 2 
 3 My_sql::My_sql()
 4 {
 5     mysql_library_init( NULL, 0, 0 );                            //初始化MySQL C API庫
 6     mysql_init( &mysql );                                        //獲取或初始化MYSQL結構。
 7     mysql_options( &mysql, MYSQL_SET_CHARSET_NAME, "utf8" );     //設置字元集
 8     mysql_real_connect( &mysql, "localhost", "root", "password", "my_sql", 0, NULL, CLIENT_MULTI_STATEMENTS );    
 9                                                                  //連接資料庫
10 }
11 My_sql::~My_sql()
12 {
13     mysql_free_result( result );      //釋放結果集使用的記憶體
14     mysql_close( &mysql );            //關閉伺服器連接 
15     mysql_server_end();               //最終確定嵌入式伺服器庫
16     mysql_library_end();              //最終確定MySQL C API庫 
17 } 
18 bool My_sql::query(const std::string &q)
19 {
20     result = NULL; 
21     mysql_query( &mysql, q.c_str() );         //執行指定為“以Null終結的字元串”的SQL查詢。 
22     result = mysql_store_result( &mysql );    //檢索完整的結果集至客戶端 
23     if ( NULL == result ) {
24         std::cerr << "Query Error!";
25         return false;
26     }
27     return true;
28 }
29 
30 unsigned My_sql::row_count()
31 {
32     return mysql_num_rows( result );      //返回集中的行數 
33 }
34 unsigned My_sql::field_count()
35 {
36     return mysql_num_fields( result );    //返回集中的列數 
37 }
38 
39 My_sql & My_sql::display_field_name(std::ostream &out, int setw_n)
40 {
41     for ( unsigned int i = 0; i < field_count(); ++i ) {
42         out << std::setw(setw_n) << ( mysql_fetch_field_direct( result, i ) -> name );
43         //給定欄位編號,返回表欄位的類型。輸出列名 
44     }
45     out << std::endl; 
46     return *this;
47 }
48 
49 My_sql & My_sql::display_result(std::ostream &out, int setw_n)
50 {
51     while( row = mysql_fetch_row( result ) )        //從結果集中獲取下一行 
52     {
53         for(int i = 0; i < field_count(); ++i )
54           {
55             if ( NULL == row[i]) {
56                 out << std::setw(setw_n) << "(NULL)";
57             }
58             else {
59                 out << std::setw(setw_n) << row[i];
60             }
61         }
62         out << std::endl; 
63     }
64     return *this;
65 }
66 
67 std::ostream & operator <<(std::ostream &out, My_sql &sql)
68 {
69     sql.display_field_name(out).display_result(out);
70     //輸出列名和結果集 
71     
72     return out;
73 }
74 
75 std::istream & operator >>(std::istream &in,  My_sql &sql)
76 {
77     std::string q;
78     std::getline(in, q);    //輸入整行 
79     if ( !sql.query(q) ) {
80         exit(1);
81     }
82     return in;
83 }
84 
85 //My_sql & operator >>(const std::string &q, My_sql &sql)
86 //{
87 //    if ( !sql.query(q) ) {
88 //        exit(1);
89 //    }
90 //    return sql;
91 //}
92 
93 My_sql & operator <<(My_sql &sql, const std::string &q)
94 {
95     if ( !sql.query(q) ) {
96         exit(1);
97     }
98     return sql;
99 }

 

 

調用實例 main.cpp

 1 #include <iostream>
 2 #include "my_sql.h"
 3 
 4 using std::cin;
 5 using std::cout;
 6 
 7 int main(int argc, char* argv[])
 8 {
 9     My_sql sql;
10     sql << "SELECT * FROM my_table";
11     cout << sql;
12     cin >> sql;
13     cout << sql;
14     return 0;
15 }

 


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

-Advertisement-
Play Games
更多相關文章
  • 本人設計了一個高效讀寫鎖,可實現多個線程讀一個線程寫的鎖,應該比Delphi自帶的讀寫鎖高效,本人沒有做對比測試。 本文的鎖不可以在一個線程里重入,否則會鎖死,另外讀寫鎖最多支持65535個線程同時讀。 ...
  • <!--?xml version="1.0" encoding="UTF-8" standalone="no"?--> elixir在1.2後增加了一個新的特性i helper. 在iex shell中使用i可以查看任意數據的數據類型和詳細描述 #查看變數描述 iex(1)> i {:test, " ...
  • spring.jar 是包含有完整發佈模塊的單個jar 包。但是不包括mock.jar, aspects.jar, spring-portlet.jar, and spring-hibernate2.jar。spring-src.zip就是所有的源代碼壓縮包。除了spring.jar 文件,Spri ...
  • 這個對象池相當小巧,支持加鎖以方便支持線程安全,當然了,如果在單線程中使用,可以指定一個偽鎖。 這個對象池並不能解決記憶體碎片問題,只是用空間換時間。這個代碼相當簡短,一看就明白,所以不寫用例了。還有這個鎖的代碼就不貼了,因為鎖的樣式各有不同,還有避免跑題,避免喧賓奪主。 上代碼: 不夠150字不允許 ...
  • JAVA Quick Java 8 or Java 7 Dev Environments With Docker Printing arrays by hacking the JVM Mobile How to Create a News Reader With React Native: Web ... ...
  • 數量 時間限制:200 ms | 記憶體限制:65535 KB 難度:0 HJS大牛想去街上吃飯,街道旁邊拴著很多狗,他想我堂堂......(省略n個字)豈會被狗咬,所以他很牛的從狗的面前經過,不管是否被上一條狗咬過,下次還會從狗的面前過(J I A N) 現在問題來了,我們給狗編號從1...n,有多 ...
  • 這個星期接到一個新的任務:解決HQ(一個用JAVA開發的開源的運維監控平臺)現在遇到的snmp升級到3.0後bug。公司用的HQ是4.6版本。於是,我把項目從gitlab上clone下來後,就開始了我的填坑之旅。坑了幾天坑,到目前,正常情況,應該只有最後一個坑了,應該是關於tomcat運行環境的。閑 ...
  • 安裝python3.5可能使用的依賴 到python官網找到下載路徑, 用wget下載 解壓tgz包 把python移到/usr/local下麵 刪除舊版本的python依賴 進入python目錄 配置 編譯 make 編譯,安裝 刪除舊的軟鏈接,創建新的軟鏈接到最新的python Enjoy yo ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...