自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

用C++連接MySQL等數(shù)據(jù)庫(kù)一

數(shù)據(jù)庫(kù) MySQL
現(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)。

現(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ù)

  1. {    
  2.    CoInitialize(NULL);   
  3.    m_pConnection.CreateInstance(__uuidof(Connection));   
  4.  
  5.    try 
  6.    {  
  7.       //設(shè)置連接時(shí)間  
  8.       m_pConnection->ConnectionTimeout = 5;  
  9.       //打開(kāi)數(shù)據(jù)庫(kù)連接  
  10.       HRESULT hr = m_pConnection->Open("DSN=MySqlODBC;server=localhost;database=test","root","root",adModeUnknown);  
  11.    }  
  12.    catch(_com_error &e)  
  13.    {  
  14.       MessageBox(NULL, e.Description(), _T(""), MB_OK);  
  15.       return FALSE;  
  16.    }   
  17.  
  18.    return TRUE;  
  19. }   
  20.  
  21. (3)執(zhí)行SQL語(yǔ)句   
  22. BOOL CDBManagerSub::ExecuteSQL( _bstr_t bstrSQL )  
  23. {  
  24.    //_variant_t RecordsAffected;  
  25.    try 
  26.    {  
  27.       // 是否已經(jīng)連接數(shù)據(jù)庫(kù)  
  28.       if(m_pConnection == NULL)  
  29.       {  
  30.          //重新連接數(shù)據(jù)庫(kù)  
  31.          Open(m_dbType, m_strServer, m_strUserName, m_strPasswor, m_strDBName);  
  32.       }  
  33.       // Connection對(duì)象的Execute方法:(_bstr_t CommandText,   
  34.       // VARIANT * RecordsAffected, long Options )   
  35.       // 其中CommandText是命令字串,通常是SQL命令。  
  36.       // 參數(shù)RecordsAffected是操作完成后所影響的行數(shù),   
  37.       // 參數(shù)Options表示CommandText的類(lèi)型:adCmdText-文本命令;adCmdTable-表名  
  38.       // adCmdProc-存儲(chǔ)過(guò)程;adCmdUnknown-未知  
  39.       _RecordsetPtr hr = m_pConnection->Execute(bstrSQL,NULL,adCmdText);  
  40.       return true;  
  41.    }   
  42.    catch(_com_error e)  
  43.    {  
  44.       MessageBox(NULL, e.Description(), _T(""), MB_OK);  
  45.       return false;  
  46.    }  
  47. }  

_bstr_t bstrSQL為輸入的SQL語(yǔ)句,如果返回TRUE,則執(zhí)行成功,返回FLASH則會(huì)報(bào)對(duì)應(yīng)的錯(cuò)誤提示。

例如下面的創(chuàng)建testTable表的SQL語(yǔ)句:

  1. char* pQuery = "create table if not exists testTable( ID VARCHAR(10), Name VARCHAR(255),Descs VARCHAR(255),PRIMARY KEY (ID))";  
  2. 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)成功。

  1. mysql> SHOW DATABASES;//顯示所有的數(shù)據(jù)庫(kù),注意一定要 敲“;”后再按回車(chē)  
  2. mysql> CREATE DATABASE mydb;//創(chuàng)建數(shù)據(jù)庫(kù)  
  3. mydbmysql> USE mydb;//選擇你所創(chuàng)建的數(shù)據(jù)庫(kù)  
  4. mydbmysql> SHOW TABLES; //顯示數(shù)據(jù)庫(kù)中的表  
  5. mysql> CREATE TABLE mytable (username VARCHAR(100), visitelist VARCHAR(200),remark VARCHAR(200),PRIMARY KEY (username));//創(chuàng)建一個(gè)表mytable: 用戶名;訪問(wèn)列表,主鍵為username  
  6. mysql> DESCRIBE mytable;//顯示表的結(jié)構(gòu) 

原文鏈接:http://www.cnblogs.com/Laokong-ServiceStation/archive/2011/04/23/2025941.html

【編輯推薦】

  1. 這些事項(xiàng)你注意了嗎? 淺談數(shù)據(jù)庫(kù)優(yōu)化注意事項(xiàng)
  2. MySQL數(shù)據(jù)庫(kù)的優(yōu)化(上)單機(jī)MySQL數(shù)據(jù)庫(kù)的優(yōu)化
  3. MySQL數(shù)據(jù)庫(kù)的優(yōu)化(下)MySQL數(shù)據(jù)庫(kù)的高可用架構(gòu)方案
  4. 微博 請(qǐng)問(wèn)你是怎么優(yōu)化數(shù)據(jù)庫(kù)的?
  5. MySQL性能優(yōu)化教程一

 

責(zé)任編輯:艾婧 來(lái)源: 博客園
相關(guān)推薦

2011-04-26 10:37:04

C++MySQL

2010-05-14 15:23:03

2010-06-12 15:53:22

MySQL數(shù)據(jù)庫(kù)

2010-02-02 17:27:16

C++連接MySqL數(shù)

2011-04-25 09:53:31

C++mysql

2011-05-24 09:18:59

C++連接mysql數(shù)據(jù)庫(kù)

2010-02-05 09:23:38

C++連接SQL數(shù)據(jù)庫(kù)

2009-08-12 14:23:01

C#連接MySql數(shù)據(jù)

2023-10-17 08:07:14

C++編程語(yǔ)言

2010-01-27 15:58:35

C++數(shù)據(jù)結(jié)構(gòu)

2011-05-26 13:42:50

MFC連接MySql數(shù)據(jù)庫(kù)

2020-09-22 15:56:31

Java

2009-03-19 10:08:09

C#數(shù)據(jù)庫(kù)查詢

2010-06-04 17:49:46

連接MySQL數(shù)據(jù)庫(kù)

2010-06-04 11:21:41

連接MySQL數(shù)據(jù)庫(kù)

2024-04-03 00:06:03

2015-10-23 14:37:56

DelphiDBExpress連接

2010-10-26 15:21:11

連接Oracle數(shù)據(jù)庫(kù)

2009-08-25 14:05:06

C#連接數(shù)據(jù)庫(kù)代碼

2009-09-04 17:23:21

C#數(shù)據(jù)庫(kù)連接對(duì)象
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)