Finding and updating a data connection

Rastaman

Board Regular
Joined
Feb 18, 2006
Messages
236
I’m hoping someone can help with a problem dealing with data connections. I’m trying to create a tool that will refresh an existing web data connection on the active sheet, prompting the user to input a new URL. This is a generic utility, intended to work on any existing data connection. My plan is as follows:

Find any data connections on the active sheet
Verify there is only one connection
Prompt user for a new URL
Refresh the query

I first want to check to see if a data connection exists. I could use something like the code below, but I haven’t figured out how to tell if the connection is on the active sheet. Also, this connection name does not work in the Querytables(TestConn).Refresh command. The TestConn name with this code matches the connections name, but the Querytables Refresh command requires the data range properties name. These two names do not match unless someone had previously renamed them to match, which I can’t count on in my generic macro.

Code:
For Each DataConn In ActiveWorkbook.Connections
    TestConn = DataConn.Name
    If ConnName = TestConn Then FoundMatch = "Yes"
Next DataConn

So instead I found that I can loop through each named range in the active sheet to find the data connection. In my testing this works well since I rarely have a named range with a scope of worksheet besides data connections. I just have to parse the resulting name string to remove the sheet name.

Code:
For Each nm In ActiveSheet.Names
    ConnName = nm.Name
    NameCount = NameCount + 1
Next nm

Since this isn’t 100% certain to find the right data connection, I am trying to loop through all data connections and validate that the named range that I found is an actual data connection. But I have the same problem that I can’t compare the named range name with the data connection name. Is there a better approach to this?

Thanks
 

Excel Facts

How to change case of text in Excel?
Use =UPPER() for upper case, =LOWER() for lower case, and =PROPER() for proper case. PROPER won't capitalize second c in Mccartney
Ok, it looks like I don't need to use the ActiveWorkbook.Connections.Name at all. Instead, I found that I can use the ActiveSheet.QueryTables(indexnumber).Name. Here's my code.

Code:
Sub EditExistingDataConnection()
'find existing data connection on the current sheet, prompt user for new URL
'abort if more than one connection found or if no data connection found
Dim TableIndex As Integer, errnum As Integer
Dim QryName As String, newURL As String

'count the number of queries in the current sheet
errnum = 0
TableIndex = 0
On Error Resume Next
Do While errnum = 0
    TableIndex = TableIndex + 1
    QryName = ActiveSheet.QueryTables(TableIndex).Name
    errnum = Err.Number
Loop

'abort if no queries or more than 1 query
If TableIndex > 2 Then
    MsgBox "duplicates data connections found on this sheet, aborting"
    Exit Sub
Else: End If
If TableIndex = 1 Then
    MsgBox "No data connect found on this sheet, aborting"
    Exit Sub
Else: End If

'get the new URL from the user and test it
newURL = InputBox("Enter the new data URL:")
If newURL = vbNullString Then Exit Sub       'exit if Cancel selected or no URL entered
If Left(newURL, 8) <> "https://" Then
    MsgBox "The URL doesn't appear to be valid, aborting"
    Exit Sub
Else: End If
If Len(newURL) >= 254 Then
    If MsgBox("The character length of the URL you pasted reached the max allowed and may have been truncated. Continue?", vbYesNo) = vbNo Then Exit Sub
Else: End If

'refresh query
    With ActiveSheet.QueryTables(QryName)
        .Connection = "URL;" & newURL
        .Refresh BackgroundQuery:=False
    End With


End Sub
 
Upvote 0

Forum statistics

Threads
1,225,738
Messages
6,186,734
Members
453,369
Latest member
juliewar

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top