views:

231

answers:

3

Can anybody tell me the effective difference between the following connection strings:

<add key="ConnectionString" value="server=tcp:192.168.0.12\Sqlserver2005;database=;user id=sa;password=;">



<add key="ConnectionString" value="server=192.168.0.12\Sqlserver2005;database=;user id=sa;password=;Network Library=DBMSSOCN;">

I believe both are effectively the same. Specifying "Network Library=DBMSSOCN" explicitly connects using TCPIP and prefixing server value with TCP does the same thing.

Please tell me if there is any difference or any performance implication of specifying these settings in web.config.

+1  A: 

DBMSSOCN is the default value of Network Library. So if you do not use it on your connection string, then it will use the default value which is "DBMSSOCN"

See:

http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlconnection.connectionstring%28VS.71%29.aspx

JCasso
+1  A: 

Concerning the Network Library=: straight from the Microsoft source:

  • dbnmpntw - Win32 Named Pipes
  • dbmssocn - Win32 Winsock TCP/IP
  • dbmsspxn - Win32 SPX/IPX
  • dbmsvinn - Win32 Banyan Vines
  • dbmsrpcn - Win32 Multi-Protocol (Windows RPC)

SQL Server uses TCP/IP by default so there's no need to specify it. A whole article on connection string can be found here.

Chris S
+3  A: 

The difference between the two options is:

Specifying the protocol

By using either,

Multiprotocol = rpc

Shared Memory = lpc

NWlink IPX / SPX = spx

Banyan VINES = vines

Apple Talk = adsp

TCP = tcp

This is the recommended way. I also feel its safer as DLL names are likelier to change than protocol names.

It also allows you to change the port number, rather than configuring it across the board by using the SQL Server Client Network Utility.

Specyfying the Library without the dll extension

Specifying the library will use the same name as the actual network DLL library file without the .dll extension.

Example:

TCP/IP: C:\WINDOWS\system32\DBMSSOCN.dll

Named Pipes: C:\WINDOWS\system32\DBNMPNTW.dll

Multiprotocol (RPC): C:\WINDOWS\system32\DBMSRPCN.dll

NWLink IPX/SPX: C:\WINDOWS\system32\DBMSSPXN.dll

AppleTalk: C:\WINDOWS\system32\DBMSADSN.dll

Banyan VINES: C:\WINDOWS\system32\DBMSVINN.dll

This will work best when you want to write your own network library. Please see SQL Server Client Network Utility.

The performance trade-off is minute and not noticeable. It is best to stick to standards and have it configured in the web.config as other developers will know where to look for the connections settings. Similar to having a data-source connection in java.

Koekiebox