日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

現(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類型庫(kù)。#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF","adoEOF")。您的環(huán)境中msado15.dll不一定在這個(gè)目錄下,請(qǐng)按實(shí)際情況修改。或者把msado15.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的類型: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è)置密碼就直接按回車,會(huì)提示服務(wù)器啟動(dòng)成功。
    mysql> SHOW DATABASES;//顯示所有的數(shù)據(jù)庫(kù),注意一定要 敲“;”后再按回車
    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)

分享到:
標(biāo)簽:幾種方法 連接 數(shù)據(jù)庫(kù) 分享 mysql
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定