汪小姐 發表於 2014-8-18 09:43:17

VB语言使用ADO连接、操作SQLServer数据库教程

<p>几年前学过的VB几乎忘光了,这几天复习了下。VB连接ADO数据库并不是非常难。</p>
<p><strong>连接第一步(要仔细看)</strong></p>
<p>对于小白来讲,这里的教程最详细,连接ADO数据库第一步,要添加什么部件呢?全称是Microsoft ADO Data Control 6.0 (SP6) (OLEDB) 部件。</p>
<p>在Microsoft ADO Data Control 6.0 (SP6) (OLEDB)部件里有一个名叫:Adodc数据控件,要将它添加。在Adodc数据控件数据位置中找到ACCES。<br />
</p>
<p align="center"><img src="https://img.jbzj.com/file_images/article/201408/201408180935059.png" alt="" /></p>
<p>控件引用的方法(值指的是姓名)<br />
<div class="codetitle"><span><U>复制代码</U></span> 代码如下:</div><div class="codebody" id="code1972"><br />
For i = 1 To Adodc1.Recordset.RecordCount<br />
&nbsp;&nbsp;&nbsp;&nbsp; If Not Adodc1.Recordset.EOF Then</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Combo1.AddItem Adodc1.Recordset.Fields("值").Value</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Adodc1.Recordset.Movenext<br />
End If<br />
Next i<br />
</div><br />
</p>
<p>该代码引用的编写者是ydl890406大大,在VB群中写这东西时,让我借用了,后来我发现有很多错误,y大神修改几次后的还是有错误,干脆重写了一遍,这就是后来的代码。时间过去的很快,VB群也解散了。后来不知为何,现在很多的教程都用了这段代码。</p>
<p>第二部分是AOD的代码连接,由于第二部分涉及到Recordset对象和Connection对象,自己学一下,完全可以自己编写。</p>
<p>何为Recordset对象和Connection对象,Connection对象是与数据源的连接,Recordset对象是操作数据。</p>
<p>寻找Microsoft ADO Data Control 6.0 (SP6) (OLEDB) 部件</p>
<p align="center"><img src="https://img.jbzj.com/file_images/article/201408/2014081809350510.png" alt="" /></p>
<p><strong>VB用ADO连接SQLServer数据库<br />
</strong></p>
<div class="jb51code">
<pre class="brush:vb;">
'数据源信息常量
Public Const conn As String = "Provider = SQLOLEDB.1;Password = sa; UserID = sa; Initial Catalog = StudentFiles; Data Source = localhost"

Public Const CONNECT_LOOP_MAX = 10 '一次执行connect操作,可以访问数据库的次数

Private IsConnect As Boolean '标记数据库是否连接

Private Connect_Num As Integer '标记执行Connect()函数后访问数据的次数

Private cnn As ADDODB.Connection '连接数据库的Connect对象

Private re As ADDODB.Recordset '保存结果集的Recordset对象

//连接数据库
Private Sub Connect()
'如果连接标记为真,则返回。
IF IsConnect = True Then
   Exit Sub
End If

Set cnn = New ADODB.Connection '关键new用于创建新对象cnn

cnn.ConnectionString = conn

cnn.Open
'判断连接的状态
If cnn.State &lt;&gt; adStateOpen Then
   MsgBox"数据库连接失败"
   End
End If

'设置连接标识,表示已经连接到数据库
IsConnect = True
End Sub


'断开与数据库的连接
Private Sub DisConnect()
Dim rc As Long

If IsConnect = False Then
   Exit Sub
End If
'关闭连接
cnn.Close
'释放cnn
Set cnn = Nothing
IsConnect = False
End Sub

'使用Connect_Num控制数据连接
Public Sub DB_Connect()
Connect_Num = Connect_Num + 1
Connect
End Sub

'使用Connect_Num控制数据断开
Public Sub DB_Disconnect()
If Connect_Num &gt;= CONNECT_LOOP_MAX Then
Connect_Num = 0
Disconnect
End If
End Sub

'强制关闭api方式访问俄的数据库,计数器复位
Public Sub DBapi_Disconnect()
Connect_Num = 0
Disconnect
End Sub

'执行数据库操作语言
'byval 就是按参数的值传递,再传递过程中,参数不会发生变化(也就是将参数值而不是将地址传递给过程的方式,这就使过程访问发哦变量的副本,过程不可改变变量的值);
与之对应的是byref,指按参数的地址传值,byref可以省略
Public Sub SQLExt(ByVal TmpSQLstmt As String )

Dim cmd As New ADODB.Command '创建Command对象cmd

DB_Connect '连接数据库

Set cmd.ActiveConnection = cnn '设置cmd的ActiveConnect属性,指定与其关联的数据库连接

cmd.CommandText = TmpSQLstmt '设置要执行的命令文本

'MsgBox TmpSQLstmt

cmd.Execute '执行命令

Set cmd = Nothing

DB_DisConnect '断开与数据库的连接

End Sub

'执行数据库查询语句
Public Function QueryExt(ByVal TmpSQLstmt As String ) As ADODB.Recordset

Dim rst As New ADODB.Recordset '创建Rescordset对象rst

DB_Connect '连接数据库

Set rst.ActiveConnection = cnn '设置rst的ActiveConnection属性,指定与其相关的数据库的连接

rst.CursorType = adOpenDynamic '设置游标类型

rst.LockType = adLockOptimistic '设置锁定类型

rst.Open TmpSQLstmt '打开记录集

Set QueryExt = rst '返回记录集

End Function

</pre>
</div>
                           
                            <div class="art_xg">
                              <b>您可能感兴趣的文章:</b><ul><li>SQL Server数据库入门学习总结</li><li>sqlserver数据库导入数据操作详解(图)</li><li>SQL Server数据库中批量导入数据的四种方法总结</li><li>c#连接sqlserver数据库、插入数据、从数据库获取时间示例</li><li>用sql脚本创建sqlserver数据库范例语句</li><li>将ACCESS数据库迁移到SQLSERVER数据库两种方法(图文详解)</li><li>如何远程连接SQL Server数据库图文教程</li><li>ASP.NET2.0 SQL Server数据库连接详解</li><li>在SQL Server数据库中为标识(IDENTITY)列插入显式值</li><li>Activiti-Explorer使用sql server数据库实现方法</li></ul>
                            </div>

                        </div>
                        <!--endmain-->
頁: [1]
查看完整版本: VB语言使用ADO连接、操作SQLServer数据库教程