在嘗試串連資料庫之前, 需要簡單說明一下串連資料庫的兩種最常見的方式: 一種是通過建立 DSN 來串連, 這種比較麻煩, 程式移植性差; 我一般採取利用 ADODB 串連資料庫的方式, 這種比較靈活方便, 不需額外工作, 方便程式移植.
下面的例子就是通過 ADODB 串連 MySQL 資料庫:
首先, 運行VB並建立一標準EXE工程, 通過菜單 工程->引用 開啟”引用”對話方塊, 找到 Microsoft ActiveX Data Objects x.x Library , 其中 x.x 是版本號碼, 可能會有很多個, 這裡我選擇的是 2.5()
單擊”確定”關閉對話方塊, 這樣就在工程中引入了 ado(ActiveX Data Objects), 然後雙擊Form設計表單, 開啟代碼視窗, 在 Form_Load 過程中輸入下面的代碼(具體說明在代碼的注釋中):
' 定義並建立資料庫連接和訪問對象
Dim cn As New ADODB.Connection
Dim rs As New ADODB.Recordset
' 定義資料庫連接字串變數
Dim strCn As String
' 定義資料庫連接參數變數
Dim db_host As String
Dim db_user As String
Dim db_pass As String
Dim db_data As String
' 定義 SQL 陳述式變數
Dim sql As String
' 初始化資料庫連接變數
db_host = "localhost"
db_user = "yourUsername"
db_pass = "yourPassword"
db_data = "yourDatabase"
' MySQL ODBC 串連參數
'+------------+---------------------+----------------------------------+
'| 參數名 | 預設值 | 說明 |
'+------------+------------------------------------------------------–+
'| user | ODBC (on Windows) | MySQL 使用者名稱 |
'| server | localhost | MySQL 伺服器位址 |
'| database | | 預設串連資料庫 |
'| option | 0 | 參數用以指定串連的工作方式 |
'| port | 3306 | 串連連接埠 |
'| stmt | | 一段聲明, 可以在串連資料庫後運行 |
'| password | | MySQL 使用者密碼 |
'| socket | | (略) |
'+------------+---------------------+----------------------------------+
' 詳細查看官方說明
' http://dev.mysql.com/doc/refman/5.0/en/myodbc-configuration-connection-parameters.html
strCn = "DRIVER={MySQL ODBC 3.51 Driver};" & _
"SERVER=" & db_host & ";" & _
"DATABASE=" & db_data & ";" & _
"UID=" & db_user & ";PWD=" & db_pass & ";" & _
"OPTION=3;stmt=SET NAMES GB2312"
' stmt=SET NAMES GB2312
' 這句是設定資料庫編碼方式
' 中文作業系統需要設定成 GB2312
' 這樣中文才不會有問題
' 版本要求 mysql 4.1+
' 串連資料庫
cn.Open strCn
' 設定該屬性, 使 recordcount 和 absolutepage 屬性可用
cn.CursorLocation = adUseClient
' 訪問表 table1
sql = "select * from table1"
rs.Open sql, cn
MsgBox rs.recordCount
很簡單吧, 剩下的就和操作其他資料庫一樣了, 最大的區別就在於一些 SQL 陳述式上.