用C++連接MySQL等數(shù)據(jù)庫(kù)一
現(xiàn)在正做一個(gè)接口,通過(guò)不同的連接字符串操作不同的數(shù)據(jù)庫(kù)。要用到mysql數(shù)據(jù)庫(kù),以前沒(méi)用過(guò)這個(gè)數(shù)據(jù)庫(kù),用access和sql server比較多。通過(guò)網(wǎng)上的一些資料和自己的摸索,大致清楚了C++連接mysql的方法??梢酝ㄟ^(guò)2種方法實(shí)現(xiàn)。
***種方法是利用ADO連接,第二種方法是利用mysql自己的api函數(shù)進(jìn)行連接。***種方法可以實(shí)現(xiàn)我當(dāng)前的需求,通過(guò)連接不同的字符串來(lái)連接不同的數(shù)據(jù)庫(kù)。暫時(shí)只連接了mysql,sqlserver,oracle,access。對(duì)于access,因?yàn)樗鼊?chuàng)建表的SQL語(yǔ)句不太兼容標(biāo)準(zhǔn)SQL語(yǔ)句,需要做一些處理,這里暫時(shí)不說(shuō)。第二種方法只能針對(duì)于mysql數(shù)據(jù)庫(kù)的連接,不過(guò)用這種方法不用安裝MyODBC服務(wù)器程序。
不管用哪種方法,首先需要安裝Mysql數(shù)據(jù)庫(kù),安裝方法請(qǐng)看“mysql安裝及一些注意點(diǎn)”。***安裝一個(gè)Navicat for mysql,方便操作mysql數(shù)據(jù)庫(kù)。下面分別說(shuō)下這兩種方法:
(一)通過(guò)ADO連接MySql數(shù)據(jù)庫(kù)
1、通過(guò)ADO連接MySql數(shù)據(jù)庫(kù),首先得安裝MyODBC服務(wù)器程序。MyODBC版本要和MySql的版本對(duì)應(yīng)上,否則會(huì)連接不上數(shù)據(jù)庫(kù)。我用的版本分別是mysql-5.1.48-win32.msi和mysql-connector-odbc-5.1.5-win32.msi。
安裝好后,點(diǎn)擊開(kāi)始菜單->設(shè)置->控制面板->管理工具->數(shù)據(jù)源(ODBC)->用戶DSN->添加->選擇MySQL ODBC 5.1 Driver。如下圖:
然后雙擊MySQL ODBC 5.1 Driver進(jìn)行配置。配置好可以點(diǎn)Test進(jìn)行下測(cè)試(如下圖),如果能連上會(huì)彈出connection successful對(duì)話框。
上圖中的Data Source Name:中的內(nèi)容就是代碼里DSN所對(duì)應(yīng)的值。例如:"DSN=MySqlODBC;server=localhost;database=test"。
2、配置好后,就可以開(kāi)始編碼了。
(1)首先導(dǎo)入ADO類(lèi)型庫(kù)。#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")。您的環(huán)境中msado15.dll不一定在這個(gè)目錄下,請(qǐng)按實(shí)際情況修改?;蛘甙裮sado15.dll這個(gè)文件拷貝到你的工程目錄下,直接#import "msado15.dll" \ no_namespace \rename ("EOF", "adoEOF")包含進(jìn)來(lái)。
(2)創(chuàng)建Connection對(duì)象并連接數(shù)據(jù)庫(kù)
- {
- CoInitialize(NULL);
- m_pConnection.CreateInstance(__uuidof(Connection));
- try
- {
- //設(shè)置連接時(shí)間
- m_pConnection->ConnectionTimeout = 5;
- //打開(kāi)數(shù)據(jù)庫(kù)連接
- HRESULT hr = m_pConnection->Open("DSN=MySqlODBC;server=localhost;database=test","root","root",adModeUnknown);
- }
- catch(_com_error &e)
- {
- MessageBox(NULL, e.Description(), _T(""), MB_OK);
- return FALSE;
- }
- return TRUE;
- }
- (3)執(zhí)行SQL語(yǔ)句
- BOOL CDBManagerSub::ExecuteSQL( _bstr_t bstrSQL )
- {
- //_variant_t RecordsAffected;
- try
- {
- // 是否已經(jīng)連接數(shù)據(jù)庫(kù)
- if(m_pConnection == NULL)
- {
- //重新連接數(shù)據(jù)庫(kù)
- Open(m_dbType, m_strServer, m_strUserName, m_strPasswor, m_strDBName);
- }
- // Connection對(duì)象的Execute方法:(_bstr_t CommandText,
- // VARIANT * RecordsAffected, long Options )
- // 其中CommandText是命令字串,通常是SQL命令。
- // 參數(shù)RecordsAffected是操作完成后所影響的行數(shù),
- // 參數(shù)Options表示CommandText的類(lèi)型:adCmdText-文本命令;adCmdTable-表名
- // adCmdProc-存儲(chǔ)過(guò)程;adCmdUnknown-未知
- _RecordsetPtr hr = m_pConnection->Execute(bstrSQL,NULL,adCmdText);
- return true;
- }
- catch(_com_error e)
- {
- MessageBox(NULL, e.Description(), _T(""), MB_OK);
- return false;
- }
- }
_bstr_t bstrSQL為輸入的SQL語(yǔ)句,如果返回TRUE,則執(zhí)行成功,返回FLASH則會(huì)報(bào)對(duì)應(yīng)的錯(cuò)誤提示。
例如下面的創(chuàng)建testTable表的SQL語(yǔ)句:
- char* pQuery = "create table if not exists testTable( ID VARCHAR(10), Name VARCHAR(255),Descs VARCHAR(255),PRIMARY KEY (ID))";
- ExecuteSQL(pQuery);
3、附上mysql數(shù)據(jù)庫(kù)的操作,方便沒(méi)有安裝Navicat for mysql的朋友參考。
打開(kāi)“開(kāi)始->所有程序->MySQL->MySQL Server 5.0->MySQL Command Line Client.exe”,如果沒(méi)有設(shè)置密碼就直接按回車(chē),會(huì)提示服務(wù)器啟動(dòng)成功。
- mysql> SHOW DATABASES;//顯示所有的數(shù)據(jù)庫(kù),注意一定要 敲“;”后再按回車(chē)
- mysql> CREATE DATABASE mydb;//創(chuàng)建數(shù)據(jù)庫(kù)
- mydbmysql> USE mydb;//選擇你所創(chuàng)建的數(shù)據(jù)庫(kù)
- mydbmysql> SHOW TABLES; //顯示數(shù)據(jù)庫(kù)中的表
- mysql> CREATE TABLE mytable (username VARCHAR(100), visitelist VARCHAR(200),remark VARCHAR(200),PRIMARY KEY (username));//創(chuàng)建一個(gè)表mytable: 用戶名;訪問(wèn)列表,主鍵為username
- mysql> DESCRIBE mytable;//顯示表的結(jié)構(gòu)
原文鏈接:http://www.cnblogs.com/Laokong-ServiceStation/archive/2011/04/23/2025941.html
【編輯推薦】
- 這些事項(xiàng)你注意了嗎? 淺談數(shù)據(jù)庫(kù)優(yōu)化注意事項(xiàng)
- MySQL數(shù)據(jù)庫(kù)的優(yōu)化(上)單機(jī)MySQL數(shù)據(jù)庫(kù)的優(yōu)化
- MySQL數(shù)據(jù)庫(kù)的優(yōu)化(下)MySQL數(shù)據(jù)庫(kù)的高可用架構(gòu)方案
- 微博 請(qǐng)問(wèn)你是怎么優(yōu)化數(shù)據(jù)庫(kù)的?
- MySQL性能優(yōu)化教程一