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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...