Jump to content
Xtreme .Net Talk

Recommended Posts

Posted

Dear All,

 

 

I'm having a bit of bother with the following code. A generic SQL exception is returned each time, but I can't for the life of me track down the problem.

   Private Function GetConnectionString(ByVal paramServer As String, ByVal paramDatabase As String) As String
       'Define the connection and command to connect to the database name server...
       Dim localConn As New System.Data.SqlClient.SqlConnection("integrated security=SSPI;data source=""stm-sysdev""; " & _
                                                                "persist security info=False;initial catalog=dbreg; ")
       Dim localComm As New System.Data.SqlClient.SqlCommand
       'Open the connection and set the properties of the connection...
       localConn.Open()
       localComm.Connection = localConn
       localComm.CommandText = "select CONNECTSTRING from dbDef where SERVER=@pServer and DBNAME=@pDatabase "
       'Define our server and database name as parameters...
       localComm.Parameters.Add(New System.Data.SqlClient.SqlParameter("pServer", paramServer))
       localComm.Parameters.Add(New System.Data.SqlClient.SqlParameter("pDatabase", paramDatabase))
       'Read the connection string from the database into the local property...
       Return localComm.ExecuteScalar().ToString
       localComm.Dispose()
       localConn.Close()
       localConn.Dispose()
   End Function

The objective of the code is simply to obtain a connection string from a central database so that we only have to add/change connection strings to this central source to affect every system that relies on it.

 

If anyone can spot what the problem is I'd be really greatful. I think I've just been looking at this too long...

 

 

Many thanks,

Paul.

  • *Experts*
Posted

The main problem is that the parameters need the @ sign on the front:

localComm.Parameters.Add(New System.Data.SqlClient.SqlParameter("@pServer", paramServer))
localComm.Parameters.Add(New System.Data.SqlClient.SqlParameter("@pDatabase", paramDatabase))

 

I added the at sign (@) to the front of pServer and pDatabase. I would highly recommend putting the column names in brackets as server and database are almost always reserved words. Like this:

localComm.CommandText = "select [CONNECTSTRING] from [dbDef] where [sERVER]=@pServer and [DBNAME]=@pDatabase"

 

I also feel obligated to say that storing a connection string in a DB seems like a bad idea... but I'll let you decide that on your own.

 

-ner

"I want to stand as close to the edge as I can without going over. Out on the edge you see all the kinds of things you can't see from the center." - Kurt Vonnegut
Posted

Thanks for that, Nerseus. I didn't try putting the @ on the front of the parameter object names, as I thought that the @ sign in the string simply identified that the following text was the parameter (a bit like a token identifying the param name starts after here...).

 

No, please - tell me more - I appreciate any details regarding programming form that you're willing to throw.

 

Recently, we underwent the threat of a mass server rename - basically, all of our servers would be renamed (regardless of what was on them) to fit into the framework of what the overlords say should be. This posed the problem that we would have to go around every single application ever written, either edit the XML, INI or registry entry, whether it be on a user's PC or server and update accordingly.

 

So, I came up with the concept of storing all of the connection strings in a database (SQLServer2000 - our DB of preference) so that modifying and recalling would take place from one location for all new systems, and would be reasonably straightforward. Our database name server would be a DB on one of our servers, hence no name change would take place.

 

Thankfully the rename has been put off for now, but it still may take place in the future...

  • *Experts*
Posted

Well this would only work if you have a webserver, but normally all DB traffic goes through a webserver. That way, only the webserver has the connection string. It often uses trusted security as well, so that no passwords are seen. The ID the webserver runs as is given permission to the DB.

 

Maybe your setup is different - maybe pure client/server with no webserver. In the main scenario that I was involved in that had pure client/server, we still had one designated server that you'd get your config information from. It could change to point to another DB server if needed, but it's name couldnt' change.

 

To help ease a server rename, you can setup a server alias (that may not be the right name). For example, you could use have "ConfigServer" point to the IP of the server that has the config information. Your app would look at something like "\\ConfigServer\Settings.xml" to get it's information. If that server is really named "SRV001" and you rename it to "SERV001XP" then you're fine - the ConfigServer alias is all that needs updating.

 

-ner

"I want to stand as close to the edge as I can without going over. Out on the edge you see all the kinds of things you can't see from the center." - Kurt Vonnegut
Posted

I see. We seem to have a series of servers all of which are directly accessible via NT authentication. Our min problem is the number of fingers in pies. Rather than have a centralised DBA, there are several DBAs all scattered around the organisation. I do like the idea of referring using a ConfigServer (as that's how our Oracle DBs used to work), but it's more political now...

 

To be honest, I'm simply a developer, writing code for databases. I've thrown together the easiest solution at a nippy pace, and may pay for this later, but it's all documented, database diagramed and so on.

 

Our other problems are basically the number of developers in different areas, all developing on different platforms, etc. We have no standard development practices - it's rather disturbing, really, considering what we do...

 

 

Thanks for your help, Nerseus.

Paul.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...