Public Function GetConn() As ADODB.Connection
    dim objConn As New ADODB.Connection 
    '如果数据库连接打开着,就不再打开
    If objConn.State <> adStateOpen Then
        '建立DB Connection 并组织SQL语句
        objConn.ConnectionTimeout = 30
        objConn.CursorLocation = adUseClient
        objConn.ConnectionString = objConn
        objConn.Open "Provider=MSDAORA.1;User ID=" & UserId & ";Password=" & PassWord & ";Data Source=" & ServerName & ";Persist Security Info=False"
    End If
    GetConn = objConn '这句话出错,对象之间的付值在vb中是如何处理的?
End Function

解决方案 »

  1.   

    对象付值要用 SET 
    Set 语句将对象引用赋给变量或属性。语法Set objectvar = {[New] objectexpression | Nothing}Set 语句的语法包含下面部分:部分 描述
    objectvar 必需的。变量或属性的名称,遵循标准变量命名约定。
    New 可选的。通常在声明时使用 New,以便可以隐式创建对象。如果 New 与 Set 一起使用,则将创建该类的一个新实例。如果 objectvar 包含了一个对象引用,则在赋新值时释放该引用。不能使用 New 关键字来创建任何内部数据类型的新实例,也不能创建从属对象。
    objectexpression 必需的。由对象名,所声明的相同对象类型的其它变量,或者返回相同对象类型的函数或方法所组成的表达式。
    Nothing 可选的。断绝 objectvar 与任何指定对象的关联。若没有其它变量指向 objectvar 原来所引用的对象,将其赋为 Nothing 会释放该对象所关联的所有系统及内存资源。
    说明为确保合法,objectvar 必须是与所赋对象相一致的对象类型。Dim、Private、Public、ReDim以及 Static 语句都只声明了引用对象的变量。在用 Set 语句将变量赋为特定对象之前,该变量并没有引用任何实际的对象。下面的示例说明了如何使用 Dim 来声明 Form1 类型的数组。Form1 实际上还没有实例。然后使用 Set 将新创建的 Form1 的实例的引用赋给 myChildForms 变量。在 MDI 应用程序中可以使用这些代码来创建子窗体。Dim myChildForms(1 to 4) As Form1
    Set myChildForms(1) = New Form1
    Set myChildForms(2) = New Form1
    Set myChildForms(3) = New Form1
    Set myChildForms(4) = New Form1通常,当使用 Set 将一个对象引用赋给变量时,并不是为该变量创建该对象的一份副本,而是创建该对象的一个引用。可以有多个对象变量引用同一个对象。因为这些变量只是该对象的引用,而不是对象的副本,因此对该对象的任何改动都会反应到所有引用该对象的变量。不过,如果在 Set 语句中使用 New 关键字,那么实际上就会新建一个该对象的实例。