用C++連接MySQL等數(shù)據(jù)庫一
現(xiàn)在正做一個(gè)接口,通過不同的連接字符串操作不同的數(shù)據(jù)庫。要用到mysql數(shù)據(jù)庫,以前沒用過這個(gè)數(shù)據(jù)庫,用access和sql server比較多。通過網(wǎng)上的一些資料和自己的摸索,大致清楚了C++連接mysql的方法??梢酝ㄟ^2種方法實(shí)現(xiàn)。
***種方法是利用ADO連接,第二種方法是利用mysql自己的api函數(shù)進(jìn)行連接。***種方法可以實(shí)現(xiàn)我當(dāng)前的需求,通過連接不同的字符串來連接不同的數(shù)據(jù)庫。暫時(shí)只連接了mysql,sqlserver,oracle,access。對(duì)于access,因?yàn)樗鼊?chuàng)建表的SQL語句不太兼容標(biāo)準(zhǔn)SQL語句,需要做一些處理,這里暫時(shí)不說。第二種方法只能針對(duì)于mysql數(shù)據(jù)庫的連接,不過用這種方法不用安裝MyODBC服務(wù)器程序。
不管用哪種方法,首先需要安裝Mysql數(shù)據(jù)庫,安裝方法請(qǐng)看“mysql安裝及一些注意點(diǎn)”。***安裝一個(gè)Navicat for mysql,方便操作mysql數(shù)據(jù)庫。下面分別說下這兩種方法:
(一)通過ADO連接MySql數(shù)據(jù)庫
1、通過ADO連接MySql數(shù)據(jù)庫,首先得安裝MyODBC服務(wù)器程序。MyODBC版本要和MySql的版本對(duì)應(yīng)上,否則會(huì)連接不上數(shù)據(jù)庫。我用的版本分別是mysql-5.1.48-win32.msi和mysql-connector-odbc-5.1.5-win32.msi。
安裝好后,點(diǎn)擊開始菜單->設(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、配置好后,就可以開始編碼了。
(1)首先導(dǎo)入ADO類型庫。#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)來。
(2)創(chuàng)建Connection對(duì)象并連接數(shù)據(jù)庫
- {
 - CoInitialize(NULL);
 - m_pConnection.CreateInstance(__uuidof(Connection));
 - try
 - {
 - //設(shè)置連接時(shí)間
 - m_pConnection->ConnectionTimeout = 5;
 - //打開數(shù)據(jù)庫連接
 - 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語句
 - BOOL CDBManagerSub::ExecuteSQL( _bstr_t bstrSQL )
 - {
 - //_variant_t RecordsAffected;
 - try
 - {
 - // 是否已經(jīng)連接數(shù)據(jù)庫
 - if(m_pConnection == NULL)
 - {
 - //重新連接數(shù)據(jù)庫
 - 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的類型:adCmdText-文本命令;adCmdTable-表名
 - // adCmdProc-存儲(chǔ)過程;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語句,如果返回TRUE,則執(zhí)行成功,返回FLASH則會(huì)報(bào)對(duì)應(yīng)的錯(cuò)誤提示。
例如下面的創(chuàng)建testTable表的SQL語句:
- 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ù)庫的操作,方便沒有安裝Navicat for mysql的朋友參考。
打開“開始->所有程序->MySQL->MySQL Server 5.0->MySQL Command Line Client.exe”,如果沒有設(shè)置密碼就直接按回車,會(huì)提示服務(wù)器啟動(dòng)成功。
- mysql> SHOW DATABASES;//顯示所有的數(shù)據(jù)庫,注意一定要 敲“;”后再按回車
 - mysql> CREATE DATABASE mydb;//創(chuàng)建數(shù)據(jù)庫
 - mydbmysql> USE mydb;//選擇你所創(chuàng)建的數(shù)據(jù)庫
 - mydbmysql> SHOW TABLES; //顯示數(shù)據(jù)庫中的表
 - mysql> CREATE TABLE mytable (username VARCHAR(100), visitelist VARCHAR(200),remark VARCHAR(200),PRIMARY KEY (username));//創(chuàng)建一個(gè)表mytable: 用戶名;訪問列表,主鍵為username
 - mysql> DESCRIBE mytable;//顯示表的結(jié)構(gòu)
 
原文鏈接:http://www.cnblogs.com/Laokong-ServiceStation/archive/2011/04/23/2025941.html
【編輯推薦】
- 這些事項(xiàng)你注意了嗎? 淺談數(shù)據(jù)庫優(yōu)化注意事項(xiàng)
 - MySQL數(shù)據(jù)庫的優(yōu)化(上)單機(jī)MySQL數(shù)據(jù)庫的優(yōu)化
 - MySQL數(shù)據(jù)庫的優(yōu)化(下)MySQL數(shù)據(jù)庫的高可用架構(gòu)方案
 - 微博 請(qǐng)問你是怎么優(yōu)化數(shù)據(jù)庫的?
 - MySQL性能優(yōu)化教程一
 















 
 
 

 
 
 
 