Chapter 8: Developing Database Applications with ADO 269 either the connection string must use the DRIVER keyword to make a DSN-less connection or the ODBC Driver Manager must prompt the user for the DSN to make a connection to SQL Server. In this example, the DRIVER keyword isn’t used and the value of adPromptComplete is specified in the Prompt property. This allows the ODBC Driver Manager to prompt the user to select an existing ODBC data source. After the user has responded to the ODBC Driver Manager prompt, the cn Connection object’s Open method connects to SQL Server. The Connection object’s Open method takes three optional parameters: ᭤ The fi rst optional parameter accepts a string that contains an OLE DB connection string. This parameter performs exactly the same function as the Connection object’s ConnectionString property, and you can use this parameter as an alternative to setting the ConnectionString property. ᭤ The second optional parameter accepts a String variable that contains a valid login ID for the target data source. ᭤ The third optional parameter accepts a String variable that can contain the password for the target data source. TIP While both OLE DB connection strings and the second and third parameters of the Open method let you specify login information, don’t use both at the same time. Because you normally need to use the OLE DB connection string to supply the name of the OLE DB provide anyway, supplying the login information as a part of the OLE DB connection string is usually simpler. Constant Description adPromptNever The ODBC Driver Manager can only use the information provided by the connection string to make a connection. If sufficient information is not supplied, the connection fails. adPromptAlways The ODBC Driver Manager always displays the ODBC Administrator to prompt for connection information. adPromptComplete The ODBC driver determines if all the required connection information has been supplied in the connection string. If all the required information is present, the connection is made without further prompting. If any of the required information is missing, the ODBC Administrator prompts the user for the missing information. adPromptCompleteRequired This option behaves like adPromptComplete, except any prompts containing information that has already been supplied are disabled. Table 8-3 ADO MSDASQL Prompt Constants 270 Microsoft SQL Server 2005 Developer’s Guide In this example, there’s no other processing, so the Close method ends the connection. Opening a DSN-less Connection with the OLE DB Provider for ODBC The previous example illustrated how to establish a SQL Server connection using the MSDASQL provider and an existing DSN. Instances occur when your application may need to make an ODBC-based connection, however, without being able to rely on a DSN being preconfigured. Luckily, the MSDASQL OLE DB provider also supports using DSN-less connections. Using a DSN-less connection removes the requirement for an existing data source. The following code illustrates how to use the ADO Connection object and the MSDASQL provider to make a DSN-less connection to SQL Server: Private Sub DSNlessConnect _ (sServer As String, sLoginID As String, sPassword As String) Dim cn As New ADODB.Connection ' DSNless Connection using the OLE DB provider for ODBC – MSDASSQL cn.ConnectionString = "DRIVER=SQL Server" & _ ";SERVER=" & sServer & _ ";UID=" & sLoginID & _ ";PWD=" & sPassword & _ ";DATABASE=AdventureWorks" cn.Open cn.Close End Sub Creating a new ADO Connection object named cn is the first action that takes place in this code example. Next, the ConnectionString property of the cn Connection object is assigned a connection string. As you might expect, because this connection string is intended to establish a DSN-less connection, it’s quite a bit different than the connection string presented in the preceding example. Because the PROVIDER keyword isn’t used, the MSDASQL provider for ODBC is used as the default. As you might guess, the DSN keyword isn’t needed to establish a DSN-less connection. Instead, the DRIVER keyword has the value of “SQL Server” to indicate the SQL Server ODBC driver should be used. NOTE Optionally, the value used by the DRIVER keyword can be enclosed in {}, as in {SQL Server}, but this isn’t a requirement. Chapter 8: Developing Database Applications with ADO 271 In addition to specifying the ODBC driver to be used, a DSN-less ODBC connection string must also indicate the server and database to be used. These values are supplied by the SERVER and DATABASE keywords. Finally, the UID and PWD keywords, described in Table 8-1, supply the required SQL Server login information. After setting the ConnectionString property with a DSN-less ODBC connection string, the Connection object’s Open method starts a connection to the SQL Server system. Then the Connection object’s Close method ends the connection. Opening a Connection with the OLE DB Provider for SQL Server The OLE DB provider for ODBC is primarily intended to enable ADO applications to access ODBC-compliant databases when no native OLE DB provider is available. While ODBC is certainly the established database access standard and is supported by virtually all popular databases, that’s not the case with OLE DB, which is a newer technology. The SQL Server 2000 OLE DB provider is supplied in sqloledb.dll. Using the OLE DB provider for SQL Server is similar to using the OLE DB provider for ODBC. Because the OLE DB provider for SQL Server doesn’t use ODBC, there’s no requirement for using a data source or an existing ODBC driver. However, you do need to specify the name of the OLE DB provider. The following example illustrates how to make a connection to SQL Server using the ADO Connection object and the OLE DB provider for SQL Server: Private Sub SQLOLEDBConnect _ (sServer As String, sLoginID As String, sPassword As String) Dim cn As New ADODB.Connection ' Connect using the OLE DB provider for SQL Server – SQLOLEDB cn.ConnectionString = "PROVIDER=SQLOLEDB" & _ ";SERVER=" & sServer & _ ";UID=" & sLoginID & _ ";PWD=" & sPassword & _ ";DATABASE=AdventureWorks" cn.Open cn.Close End Sub As in the previous examples, an instance of the ADO Connection object is created. Then the ConnectionString property of the ADO Connection object is assigned an 272 Microsoft SQL Server 2005 Developer’s Guide OLE DB connection string. This connection string uses the PROVIDER keyword to specify the SQLOLEDB provider is used. Specifying the PROVIDER keyword is required to use the OLE DB provider for SQL Server. If you omit this keyword, the provider defaults to the value of MSDASQL (the OLE DB provider for ODBC). In addition, the SERVER and DATABASE keywords are also required. The SERVER keyword specifies the name of the SQL Server system that will be connected to, and the DATABASE keyword identifies the database to be used. The UID and PWD keywords provide the authentication values required to log in to SQL Server if you are connecting using mixed security. If you are connecting using NT Authentication, the UID and PWD keywords are ignored, as the login will use your Windows NT user name and password. Table 8-4 lists all the provider-specific keywords provided by Microsoft’s OLE DB Provider for SQL Server. TIP As the preceding listing demonstrates, you can freely mix the provider-specific connection string keywords with the generic OLE DB connection string keywords in the connection string. Keyword Description TRUSTED_CONNECTION Uses a value of YES or NO to indicate where a value of YES indicates Windows NT authentication is to be used and a value of NO indicates mixed or SQL Server authentication should be used. CURRENT LANGUAGE Specifies the SQL Server language name to be used for this connection. NETWORK ADDRESS Specifies the SQL Server network address. NETWORK LIBRARY Specifies the network library DLL to be used. The value used by this keyword should not include the path of the .dll file extension. USE PROCEDURE FOR PREPARE Uses a value of YES or NO to indicate whether SQL Server should create temporary stored procedures for each prepared command. AUTO TRANSLATE Uses a value of TRUE or FALSE, where FALSE prevents automatic ANSI/ multibyte character conversions. The default value of TRUE automatically converts the data transferred between the SQL server and the client. PACKET SIZE Used to alter the network packet size. Accepts values from 512 to 32767. If no value is specified, a default packet size of 4096 is used. APPLICATION NAME Identifies the current application. WORKSTATION ID Identifies the client workstation. Table 8-4 Connection String Keyword for the OLE DB Provider for SQL Server Chapter 8: Developing Database Applications with ADO 273 After setting the ConnectionString property, the Open method starts the connection. Once the connection has been established, other database access can be performed. In this example, there’s no additional work, so the connection is closed using the Close method. TIP If you are connecting to a named instance of SQL Server 2005, you need to use the named instance name in conjunction with the SERVER keyword. For instance, to connect to a named instance other than the default instance, you would use the following format with the SERVER keyword: SERVER=computername\instancename. And to connect to the instance named TestServer on the computer named teca4, for example, you would use the following form of the SERVER keyword: SERVER=teca4\TestServer. Opening a Trusted Connection using the OLE DB Provider for SQL Server The preceding example illustrated how to establish a SQL Server connection using the SQLOLEDB Provider and SQL Server Security (aka mixed security). However, using NT Security, also known as Integrated Security, provides for a more secure connection because the same values used for the client’s Windows login are also used for SQL Server authentication—there’s no need to specify the user ID or the password from the application. In addition, Integrated Security can make administration easier by eliminating the need to create a set of SQL Server login IDs that are separate from the Windows NT/2000 User IDs. The following example illustrates how to make a trusted connection to SQL Server using the ADO Connection object and the OLE DB provider for SQL Server: Private Sub SQLOLEDBTrustedConnect _ (sServer As String, sLoginID As String, sPassword As String, _ bIntegratedSecurity As Boolean) Dim cn As New ADODB.Connection ' Connect using the SQLOLEDB provider cn.ConnectionString = "PROVIDER=SQLOLEDB" & _ ";SERVER=" & sServer & _ ";DATABASE=AdventureWorks" ' Use the Trusted_Connection keyword for integrated security If bIntegratedSecurity = True Then cn.ConnectionString = cn.ConnectionString _ & ";TRUSTED_CONNECTION=YES" Else ' Otherwise supply the LoginID and Password cn.ConnectionString = cn.ConnectionString & ";UID=" _ 274 Microsoft SQL Server 2005 Developer’s Guide & sLoginID & ";PWD=" & sPassword End If cn.Open cn.Close End Sub In the beginning of this subroutine, you can see where the server name, login ID, and password are passed in the subroutine as String values. In addition, the bIntegratedSecurity Boolean variable is used to indicate whether the SQL Server connection should be made using Integrated Security or SQL Server Security. A value of True indicates Integrated Security is to be used, while a value of False indicates the connection will use SQL Server Security. Next, an instance of the ADO Connection object is created and the ConnectionString property is assigned. As in the previous example, the connection string uses the PROVIDER keyword to specify the SQLOLEDB provider, and the DATABASE keyword should set AdventureWorks as the default database. Then the bIntegratedSecurity variable is tested for a value of True. If the bIntegratedSecurity variable is true, then Integrated Security is be used and the TRUSTED_CONNECTION=YES keyword is appended to the connection string. Otherwise, SQL Server Security is to be used, and the UID and PWD keywords are used to provide the SQL Server authentication information. After the ConnectionString has been set up, the ADO Connection object’s Open method is used to connect to SQL Server. In this example, after the connection has been established, it is immediately closed using the Connection object’s Close method. Open a Connection Using the Connection Object’s Properties All the previous examples have illustrated connecting to SQL Server using values supplied via the Connection object’s ConnectionString property. While providing server and database connection information is certainly a requirement to establish an ADO connection to SQL Server, using the ConnectionString property is not. You can also provide all the required connection information using the ADO Connection object’s Extended Properties. Unlike standard ADO object properties that can be viewed using the Object Browser, Extended Properties access provider-specific information that isn’t explicitly available in the standard ADO Connection object. The following example illustrates how to set up a SQL Server connection using the ADO Connection object’s extended properties: Private Sub SQLOLEDBPropertiesConnect _ (sServer As String, sLoginID As String, sPassword As String, _ bIntegratedSecurity As Boolean) Chapter 8: Developing Database Applications with ADO 275 Dim cn As New ADODB.Connection ' Specify the OLE DB provider cn.Provider = "sqloledb" ' Set the extended connection properties cn.Properties("Data Source").Value = sServer cn.Properties("Initial Catalog").Value = "AdventureWorks" ' Check for Integrated security If bIntegratedSecurity = True Then cn.Properties("Integrated Security").Value = "SSPI" Else cn.Properties("User ID").Value = sLoginID cn.Properties("Password").Value = sPassword End If cn.Open cn.Close End Sub String variables containing the server name, login ID, and password are passed in to the beginning of this subroutine, followed by the bIntegratedSecurity Boolean variable, which indicates whether Integrated Security will be used. Like the previous example, a value of True indicates Integrated Security is to be used, while a value of False indicates the connection will use SQL Server security. Next, an instance of the ADO Connection object is created and its Provider property is set to sqloledb, the name of the SQL Server OLE DB provider. After the Provider property is set, then the specific connection values are assigned to the Connection object’s Extended Properties. Each Extended Property is located in the Properties collection by using its name. For instance, the Data Source property is identified using the “Data Source” string, and its value is set to the name of the SQL Server instance to which the application intends to connect. Next the Initial Catalog property is assigned the name of the AdventureWorks database, which causes AdventureWorks to be used as the default database. TIP While you can’t see the available extended properties using the Object Browser, you can see them in the Debugger by adding an instance of the Connection object to the Watch List, and then expanding the Properties collection. Each Extended Property is listed as Item n (where n uniquely numbers each property). And as you might expect, the Name property contains the Extended Properties’ name, while the Value property contains its value. 276 Microsoft SQL Server 2005 Developer’s Guide Then the bIntegratedSecurity variable is tested for a value of True. If the bIntegratedSecurity variable is True, then the Integrated Security property is set to a value of Security Support Provider Interface (SSPI), to specify Windows NT Authentication. Otherwise, the User ID and Password connection properties are assigned values and SQL Server Security is used for the connection authentication. After the Connection object’s Extended Properties have been assigned connection values, the Open method is used to connect to SQL Server. The connection is then closed using the Connection object’s Close method. Connecting to SQL Server Using a UDL File A Universal Data Link (UDL) file is the OLE DB equivalent to an ODBC File DSN. Like an ODBC File DSN, a UDL file stores OLE DB connection information, such as the provider, server, database username, password, and other connection options you can use to establish an ADO connection. One of the advantages to using a UDL file is that an administrator or developer can centrally create the UDL file, which can then be distributed to all networked clients along with the application. From an application developer’s standpoint, using a UDL file to connect to SQL Server is similar to using the standard OLE DB connection string. The following example illustrates how you can use an existing UDL file to connect to SQL Server. Private Sub SQLOLEDBUDLConnect() Dim cn As New ADODB.Connection ' Connect using the OLE DB Provider for SQL Server – SQLOLEDB cn.ConnectionString = "FILE NAME=" & App.Path & \\udlSample.udl cn.Open cn.Close End Sub First an instance of the ADO Connection object is created, and then the ConnectionString property of the Connection object is assigned a string consisting of the FILE NAME= keyword, followed by the path and name of the UDL that contains the SQL Server connection information. In this example, the udlsample.udl file is located in the same directory as the VB database application. If the application were located in the c:\DBApp directory, the resolved connection string would then appear as follows: "FILE NAME=C:\DBApp\udlsample.udl" After the Connection object’s ConnectionString property has been assigned the FILE NAME keyword and the path to the existing UDL, the Open method is used to Chapter 8: Developing Database Applications with ADO 277 connect to SQL Server. The connection is then closed using the Connection object’s Close method. Connecting to SQL Server Using the Data Link Dialog Just as it’s possible to cause the ODBC driver to prompt the user for any required connection parameters at run time, it’s also possible to prompt for the required OLE DB connection values at run time. However, nothing that’s inherently a part of either OLE DB or ADO lets you prompt for the connection attributes. Instead, OLE DB connection properties are captured at run time using the DataLink dialog, which is a part of the OLE DB Service object. Adding a Reference to the OLE DB Service Object Before you can use the Data Link dialog box from your Visual Basic application, you must add a reference to the Microsoft OLE DB Service Component 1.0 Type Library, as well as a reference to the Microsoft ActiveX Data Objects 2.8 Library. To add a reference to Visual Basic, select the References option from Visual Basic’s Project menu. The References dialog box shown in Figure 8-7 is then displayed. When the References dialog box is first displayed, scroll through the list of references until you see the Microsoft OLE DB Service 1.0 Type Library. Figure 8-7 Adding the OLE DB Service Component Type Library 278 Microsoft SQL Server 2005 Developer’s Guide Clicking the check box immediately in front of the name, and then clicking the OK button adds a reference to the OLE DB Service Library to the current VB project. After a reference to the OLE DB Service Library has been added to your project, you can use Visual Basic’s Object Browser to view the object’s properties and methods, as shown in Figure 8-8. After a reference to the OLE DB Service Component 1.0 Type Library is added to VB, you can then create an instance of the Data Link object in your application that displays the OLE DB connection prompts to the end user. The following code listing shows the code to display the Data Link dialog box: Private Sub SQLOLEDBPromptConnect(cn As ADODB.Connection) Dim dl As New MSDASC.DataLinks ' Display the Data Link Dialog Set cn = dl.PromptNew On Error Resume Next Figure 8-8 Viewing the DataLink object in the Object Browser . SQL Server 2000 OLE DB provider is supplied in sqloledb.dll. Using the OLE DB provider for SQL Server is similar to using the OLE DB provider for ODBC. Because the OLE DB provider for SQL Server. keyword: SERVER= teca4TestServer. Opening a Trusted Connection using the OLE DB Provider for SQL Server The preceding example illustrated how to establish a SQL Server connection using the SQLOLEDB. illustrates how to make a connection to SQL Server using the ADO Connection object and the OLE DB provider for SQL Server: Private Sub SQLOLEDBConnect _ (sServer As String, sLoginID As String,