- 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-hant/n/126608.html