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

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

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

現(xiàn)在正做一個接口,通過不同的連接字符串操作不同的數(shù)據(jù)庫。要用到mysql數(shù)據(jù)庫,以前沒用過這個數(shù)據(jù)庫,用access和sql server比較多。通過網(wǎng)上的一些資料和自己的摸索,大致清楚了C++連接mysql的方法。可以通過2種方法實現(xiàn)。

第一種方法是利用ADO連接,第二種方法是利用mysql自己的api函數(shù)進行連接。第一種方法可以實現(xiàn)我當(dāng)前的需求,通過連接不同的字符串來連接不同的數(shù)據(jù)庫。暫時只連接了mysql,sqlserver,oracle,access。對于access,因為它創(chuàng)建表的SQL語句不太兼容標準SQL語句,需要做一些處理,這里暫時不說。第二種方法只能針對于mysql數(shù)據(jù)庫的連接,不過用這種方法不用安裝MyODBC服務(wù)器程序。
不管用哪種方法,首先需要安裝Mysql數(shù)據(jù)庫,安裝方法請看“mysql安裝及一些注意點”。最好安裝一個Navicat for mysql,方便操作mysql數(shù)據(jù)庫。下面分別說下這兩種方法:
(一)通過ADO連接MySql數(shù)據(jù)庫
1、通過ADO連接MySql數(shù)據(jù)庫,首先得安裝MyODBC服務(wù)器程序。MyODBC版本要和MySql的版本對應(yīng)上,否則會連接不上數(shù)據(jù)庫。我用的版本分別是mysql-5.1.48-win32.msi和mysql-connector-odbc-5.1.5-win32.msi。
安裝好后,點擊開始菜單->設(shè)置->控制面板->管理工具->數(shù)據(jù)源(ODBC)->用戶DSN->添加->選擇MySQL ODBC 5.1 Driver。如下圖:
   

然后雙擊MySQL ODBC 5.1 Driver進行配置。配置好可以點Test進行下測試(如下圖),如果能連上會彈出connection successful對話框。

上圖中的Data Source Name:中的內(nèi)容就是代碼里DSN所對應(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不一定在這個目錄下,請按實際情況修改。或者把msado15.dll這個文件拷貝到你的工程目錄下,直接#import "msado15.dll" \ no_namespace \rename ("EOF", "adoEOF")包含進來。
 (2   創(chuàng)建Connection對象并連接數(shù)據(jù)庫  
  {     
        CoInitialize(NULL);
        m_pConnection.CreateInstance(__uuidof(Connection));

        try
        {
                //設(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對象的Execute方法:(_bstr_t CommandText,
                // VARIANT * RecordsAffected, long Options )
                // 其中CommandText是命令字串,通常是SQL命令。
                // 參數(shù)RecordsAffected是操作完成后所影響的行數(shù),
                // 參數(shù)Options表示CommandText的類型:adCmdText-文本命令;adCmdTable-表名
                // adCmdProc-存儲過程;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則會報對應(yīng)的錯誤提示。
      例如下面的創(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è)置密碼就直接按回車,會提示服務(wù)器啟動成功。
    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)建一個表mytable: 用戶名;訪問列表,主鍵為username
    mysql> DESCRIBE mytable;//顯示表的結(jié)構(gòu)

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

網(wǎng)友整理

注冊時間:

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

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

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

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

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

答題星2018-06-03

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

全階人生考試2018-06-03

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

運動步數(shù)有氧達人2018-06-03

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

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

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

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定