C語言連接Mysql資料庫,執行mysql_query()或mysql_real_query()時出錯,即返回值為1解決辦法

来源:https://www.cnblogs.com/rogunt/archive/2020/06/06/13057670.html
-Advertisement-
Play Games

出現這種問題,我這裡遇到的原因是因為上一次查詢的結果集沒有釋放完全,導致查詢失敗 此時的錯誤內容是:Commands out of sync; you can't run this command now 該錯誤內容由mysql_error(conn)語句輸出。 如果你在上次查詢時忘了調用mysql ...


出現這種問題,我這裡遇到的原因是因為上一次查詢的結果集沒有釋放完全,導致查詢失敗

此時的錯誤內容是:Commands out of sync; you can't run this command now

該錯誤內容由mysql_error(conn)語句輸出。

 

如果你在上次查詢時忘了調用mysql_free_result();

那就回去加一行就可以了。

如果還是不好使,請繼續往下看。

 

很有可能你是在上次查詢中調用了多條SELECT語句或調用了存儲過程。在這種情況下,需要對mysql_real_connect()中的參數進行修改。

一般情況下,我們最後一個參數寫的是0,但是如果你調用了存儲過程,即返回集可能不只有一個,就需要將最後一個參數變成CLIENT_MULTI_STATEMENTS。

此外,該參數的其他值請參閱Mysql文檔我查閱的中文網(非官方)

 

假如你還是不好使,那麼你需要在原先釋放結果集的地方,將原來的代碼替換成

    while (!mysql_next_result(conn))
    {
        res = mysql_store_result(conn);
        mysql_free_result(res);
    }

其中conn是連接句柄,res是結果集

下麵給上我的全部代碼,該代碼僅供參考,我將我的主機名刪去了。

 1 #include <stdio.h>
 2 #include <string.h>
 3 #include <mysql/mysql.h>
 4 int main()
 5 {
 6     int temppppp;
 7     char sql[100];                                                   //存放SQL語句
 8     char host[46] = ""; //MySQL資料庫主機名
 9     char dburl[8] = "normal";                                        //資料庫名稱
10     const char username[9] = "arknight";                             //用戶名
11     const char password[9] = "arknight";                             //密碼
12     unsigned int port = 3306;                                        //埠號
13     MYSQL *conn;                                                     //Mysql連接指針
14     MYSQL_RES *res;                                                  //Mysql結果集
15     MYSQL_ROW row;                                                   //行變數
16     printf("正在嘗試連接資料庫\n");
17     if ((conn = mysql_init((MYSQL *)0))                                                                                                                                       //初始化MYSQL
18         && (mysql_options(conn, MYSQL_SET_CHARSET_NAME, "utf8") == 0)                                                                                                         //開始連接
19         && mysql_set_server_option(conn, MYSQL_OPTION_MULTI_STATEMENTS_ON) 
20         && mysql_real_connect(conn, host, username, password, dburl, port, NULL, CLIENT_MULTI_STATEMENTS)) //連接成功
21     {
22         puts("連接成功");
23     }
24     else
25     {
26         puts("無法連接資料庫");
27         exit(-1);
28     }
29 
30     int i = 0;
31     int ret = 0;
32 
33     strcpy(sql, "call gettype");
34     puts(".............................................");
35     ret = mysql_real_query(conn, sql, strlen(sql));
36     printf("******%d\n", ret);
37     res = mysql_store_result(conn);
38     i = (int)mysql_num_rows(res);
39     for (int a = 0; a < i; a++)
40     {
41         row = mysql_fetch_row(res);
42         if (row == NULL)
43         {
44             break;
45         }
46         printf("%s\t%s\n", row[0], row[1]);
47     }
48     while (!mysql_next_result(conn))
49     {
50         res = mysql_store_result(conn);
51         mysql_free_result(res);
52     }
53     //輸出完成
54     printf("FINISHED\n");
55 
56     strcpy(sql, "select * from showall");
57     puts(".............................................");
58     ret = mysql_real_query(conn, sql, strlen(sql));
59     printf("%s", mysql_error(conn));
60     printf("******%d\n", ret);
61     res = mysql_store_result(conn);
62     i = (int)mysql_num_rows(res);
63     for (int a = 0; a < i; a++)
64     {
65         row = mysql_fetch_row(res);
66         if (row == NULL)
67         {
68             break;
69         }
70         printf("%s\t%s\t%s\t%s\t%s\n", row[0], row[1], row[2], row[3], row[4]);
71     }
72     while (!mysql_next_result(conn))
73     {
74         res = mysql_store_result(conn);
75         mysql_free_result(res);
76     }
77 
78     mysql_close(conn);
79     return 0;
80 }
View Code

 


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

-Advertisement-
Play Games
更多相關文章
  • 前面幾章蜻蜓點水的介紹了elasticsearch、apm相關的內容。本片主要介紹怎麼使用ELK Stack幫助我們打造一個支撐起日產TB級的日誌監控系統 背景 在企業級的微服務環境中,跑著成百上千個服務都算是比較小的規模了。在生產環境上,日誌扮演著很重要的角色,排查異常需要日誌,性能優化需要日誌, ...
  • 消息中間件作為分散式系統的重要成員,各大公司及開源均有許多解決方案。目前主流的開源解決方案包括RabbitMQ、RocketMQ、Kafka、ActiveMQ等。消息這個東西說簡單也簡單,說難也難。簡單之處在於好用方便,接入簡單使用簡單,非同步操作能夠解耦系統間的依賴,同時失敗後也能夠追溯重試。難的地 ...
  • 0 專輯概述 etcd 是雲原生架構中重要的基礎組件,由 CNCF 孵化托管。etcd 在微服務和 Kubernates 集群中不僅可以作為服務註冊與發現,還可以作為 key-value 存儲的中間件。 《徹底搞懂 etcd 系列文章》將會從 etcd 的基本功能實踐、API 介面、實現原理、源碼分 ...
  • 狀態模式用於解決系統中複雜對象的狀態轉換以及不同狀態下行為的封裝問題 模式動機 很多情況下,一個對象的行為取決於一個或多個動態變化的屬性,這樣的屬性叫做狀態。一個對象可以擁有多個狀態,這些狀態可以相互轉換,當對象狀態不同時,其行為也有所差異。 假設一個人就是對象,人根據心情不同會有很多狀態,比如開心 ...
  • 對於python中pip安裝庫文件超時問題 找了好多方法,發現更換安裝源最適合我 方案一:對於比較小的庫,可以延時處理 pip --default-timeout=100 install -U pip pip --default-timeout=100 install 第三方庫名方案二:更換安裝源 ...
  • https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1591472927710&di=fdd3da90a98ed401c87ddaf96fdbade2&imgtype=0&src=http%3A%2F%2F5b098... ...
  • 一 安裝jdk zookeeper是採用java開發的,所以需要依賴jdk環境,我們需要先安裝jdk,最便捷的方式就是採用yum,但是yum的官方源速度很慢,我們可以先更換yum源; #備份初始源 mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos ...
  • 內容不涉及演算法相關內容,paxos演算法,zab協議等網路上已經有很多優秀的文章,這裡就不獻醜了 什麼是Zookeeper ZooKeeper是分散式應用程式的分散式協調服務,是Google的Chubby一個開源的實現,是Hadoop和Hbase的重要組件。它是一個為分散式應用提供一致性服務的軟體,提 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...