mysqlc(mysql查看錶結構)

  • 1、C語言怎樣連接mysql資料庫
  • 2、mysql c語言 游標能取多行嗎
  • 3、如何使用mysql的C介面訪問mysql資料庫
  • 4、如何在MYSQL中用C語言實現事務處理
  • 5、如何用C語言連接MYSQL資料庫

mysql是有c語言介面的,安裝相應庫後就可以鏈接了,一般連接mysql的函數是mysql_connect或者mysql_real_connect(大概就是這麼拼的吧。。。)可以使用mysql_query執行sql語句

1、 無返回結果語句,如:INSERT,UPDATE,DROP, DELETE等

2、 select語句返回單行變數並可傳給本地變數(select ..into)

3、 返回多行結果集的select語句,並可使用MySQL游標循環處理

注意,存儲過程返回的多行結果集,可以被客戶端程序(如php)所接收,但要在一個存儲過程中接收另一個存儲過程的結果集是不可能的,一般解決辦法是存入臨時表供其它過程共用

4、 prepare語句

以下主要講述游標及prepare部分

游標

定義

DECLARE cursor_name CURSOR FOR SELECT_statement;

游標操作

OPEN 打開游標

OPEN cursor_name;

FETCH 獲取游標當前指針的記錄,並傳給指定變數列表,注意變數數必須與MySQL游標返回的欄位數一致,要獲得多行數據,使用循環語句去執行FETCH

FETCH cursor_name INTO variable list;

CLOSE關閉游標

CLOSE cursor_name ;

注意:MySQL的游標是向前只讀的,也就是說,你只能順序地從開始往後讀取結果集,不能從後往前,也不能直接跳到中間的記錄.

一個完整的例子:

定義本地變數

DECLARE o varchar(128);

定義游標

DECLARE ordernumbers CURSOR

FOR

SELECT callee_name FROM account_tbl where acct_timeduration=10800;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_departments=1;

SET no_more_departments=0;

打開游標

OPEN ordernumbers;

循環所有的行

REPEAT

— Get order number

FETCH ordernumbers INTO o;

update account set allMoneyallMoney=allMoney+72,lastMonthConsumelastMonthConsume=lastMonthConsume-72 where NumTg=@o;

循環結束

UNTIL no_more_departments

END REPEAT;

關閉游標

CLOSE ordernumbers;

DELIMITER $$

USE `kubauser`$$

DROP PROCEDURE IF EXISTS `cursortest`$$

CREATE DEFINER=`coo8new`@`%` PROCEDURE `cursortest`(OUT a VARCHAR(50),OUT b VARCHAR(50))

BEGIN

DECLARE _outuserid VARCHAR(50);

DECLARE _kubauserid VARCHAR(50);

DECLARE flag INT;

DECLARE update_cursor CURSOR

FOR

SELECT outuserid,kubauserid FROM ecuser_cooperationuser;

DECLARE CONTINUE HANDLER FOR NOT FOUND SET flag=1;

SET flag=0;

OPEN update_cursor;

REPEAT /*循環*/

FETCH update_cursor INTO _outuserid,_kubauserid;

SET a=_outuserid;

SET b=_kubauserid;

/*update set where*/

UNTIL flag

END REPEAT;

CLOSE update_cursor ;

END$$

DELIMITER ;

轉載,僅供參考。

調用mysql資料庫API。

去官網下載mysql c API庫文件,然後安裝一下,每個調用資料庫的函數都有相關解釋,直接參照函數解釋進行編程就行了。

注意編寫makefile的時候把相關依賴庫加入

假如用戶輸入的姓名和年齡值分別保存在變數name,age中:

char sql_insert[200];

sprintf(sql_insert, “INSERT INTO table values(‘%s’,’%d’);”, name, age);

mysql_query(mysql_conn, sql_insert);

上述語句在執行完sprintf語句後,sql_insert中保存的是INSERT查詢語句字元串,sql_insert作為mysql_query()語句的參數即可實現正確的插入。

1、配置ODBC數據源。

2、使用SQL函數進行連接。

對於1、配置數據源,配置完以後就可以編程操作資料庫了。

對於2、使用SQL函數進行連接,參考代碼如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

#includewindows.h

#includesql.h

#includesqlext.h

void main()

{

HENV henv; //環境句柄

HDBC hdbc; //數據源句柄

HSTMT hstmt; //執行語句句柄

unsigned char datasource[]=”數據源名稱”; //即源中設置的源名稱

unsigned char user[]= “用戶名”; //資料庫的帳戶名

unsigned char pwd[]= “密碼”; //資料庫的密碼

unsigned char search[]=”select xm from stu where xh=0″;

SQLRETURN retcode; //記錄各SQL函數的返回情況

// 分配環境句柄

retcode= SQLAllocEnv(henv); // 等介於 SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL

, henv);

// 設置ODBC環境版本號為3.0

retcode= SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (void*)SQL_OV_ODBC3, 0);

// 分配連接句柄

retcode= SQLAllocConnect(henv,hdbc); // 等介於 SQLAllocHandle(SQL_HANDLE_DBC, henv, hdbc);

//設置連接屬性,登錄超時為*rgbValue秒(可以沒有)

// SQLSetConnectAttr(hdbc, SQL_LOGIN_TIMEOUT, (SQLPOINTER)(rgbValue), 0);

//直接連接數據源

// 如果是windows身份驗證,第二、三參數可以是

原創文章,作者:PJ0V9,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/126608.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
PJ0V9的頭像PJ0V9
上一篇 2024-10-03 23:09
下一篇 2024-10-03 23:09

相關推薦

  • 如何修改mysql的埠號

    本文將介紹如何修改mysql的埠號,方便開發者根據實際需求配置對應埠號。 一、為什麼需要修改mysql埠號 默認情況下,mysql使用的埠號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Vue TS工程結構用法介紹

    在本篇文章中,我們將從多個方面對Vue TS工程結構進行詳細的闡述,涵蓋文件結構、路由配置、組件間通訊、狀態管理等內容,並給出對應的代碼示例。 一、文件結構 一個好的文件結構可以極…

    編程 2025-04-29
  • Python程序的三種基本控制結構

    控制結構是編程語言中非常重要的一部分,它們指導著程序如何在不同的情況下執行相應的指令。Python作為一種高級編程語言,也擁有三種基本的控制結構:順序結構、選擇結構和循環結構。 一…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28
  • MySQL左連接索引不生效問題解決

    在MySQL資料庫中,經常會使用左連接查詢操作,但是左連接查詢中索引不生效的情況也比較常見。本文將從多個方面探討MySQL左連接索引不生效問題,並給出相應的解決方法。 一、索引的作…

    編程 2025-04-28
  • Lidar避障與AI結構光避障哪個更好?

    簡單回答:Lidar避障適用於需要高精度避障的場景,而AI結構光避障更適用於需要快速響應的場景。 一、Lidar避障 Lidar,即激光雷達,通過激光束掃描環境獲取點雲數據,從而實…

    編程 2025-04-27
  • CentOS 7在線安裝MySQL 8

    在本文中,我們將介紹如何在CentOS 7操作系統中在線安裝MySQL 8。我們會從安裝環境的準備開始,到安裝MySQL 8的過程進行詳細的闡述。 一、環境準備 在進行MySQL …

    編程 2025-04-27
  • 如何使用MySQL欄位去重

    本文將從多個方面為您詳細介紹如何使用MySQL欄位去重並給出相應的代碼示例。 一、SELECT DISTINCT語句去重 MySQL提供了SELECT DISTINCT語句,通過在…

    編程 2025-04-27

發表回復

登錄後才能評論