Skip to content

Latest commit

 

History

History
97 lines (63 loc) · 4.35 KB

README.md

File metadata and controls

97 lines (63 loc) · 4.35 KB

Workaround for dynamic aliasing of Linked Servers in MS SQL Server

Microsoft SQL server doesn't allow us to have a reference to a linked server or to have dynamic aliases. This is the infamous feature and view of Microsoft, for decades. There are no aliases for server-level objects.

My workaround does a dynamic modifications and cloning of an existing and tested stored procedure for every linked server.
It is kinda hiding any dynamic SQL under the hood.

The workaround can overcome:

  • Need to pass a name of a linked server as a parameter to a stored procedure.
  • Store linked server name in a variable to modify and invoke it dynamically.
  • Need to interact with hundreds of tables and views. Using of another approaches from over the Internet (listed below) will cause complications.

This technique will allow your team to retain straightforward, standard and well-known development.
But, you have to look at things from the other side.

If all your environments (dev, test, UAT, production) has only one linked server.
It is better to use named linked servers. Convert your existing linked server name [MyServer\MyInstance] to a common name [MyLinkedServer], which will refer to different SQL Server instances on different environments.

How to use

~ Create all linked servers you need.
You may have only one primary linked server on dev- and test stands.

~ Create an initial stored procedure to use the primary linked server.

~ Install the CloneSP stored procedure on your database.

~ During a deployment process create a cloned stored procedures for each other linked servers as the example shows in the try-me-after-install-CloneSP.sql.
Do not invoke the cloning for not existing linked servers in the current environment.

EXECUTE CloneSP
  @source_name = '[dbo].[MySampleSP]',
  @target_name = '[dbo].[MyClonedSP]',
  
  @sub1_from = 'Server_level_alias__Linked_server',
  @sub1_to = 'Replaced_alias__Other_linked_server',
  
  @sub2_from = 'MySampleSP',
  @sub2_to = 'MyClonedSP'
;

~ Use the cloned stored procedures where the initial procedure is used.
You can use a lightweight dynamic T-SQL logic for it, now.
You can check the existence of a linked-server or its related stored procedure.

~ Use your brain for others stuff. Or ask me if any troubles.

How the workaround works

~ It takes source code of a stored procedure and replaces a name of the stored procedure and name of an used linked server.

~ Look at an example of usage in the try-me-after-install-CloneSP.sql

~ Look at the implementation in CloneSP

Advantages of the workaround

  • It gives code compiled by SQL Server on your target environment.
  • Your dev-team may don't know about other linked servers. Only about the primary one.
  • Your dev-team shouldn't duplicated code for another linked servers.

Disadvantages of the workaround

  • It forces you to create a huge stored procedures. For small procedures you just have to run CloneSP more often and you can forget something that was recently added.

Other solutions

~ Generating stored procedures outside of SQL Server (say, during the deployment process).
It is more difficult to get code compiled on your target environment.

~ Dynamic aliases for objects in a linked-server (created dynamically in a loop).
Example: MyLinkedServer.MyDb.dbo.MyTable -> Prefix_MyTable

No fast switching.
Pain for huge codebase.
More error prone and tough supporting.

~ A network alias switching

It blocks various automation.
There is no exact point in the time of the switching.

~ Dynamic SQL

This is more error prone approach.
It has expensive support even for middle level databases.
Debug, development, bug-fixing with a pain.

Credits

Marat Gumerov for the idea.

Links

Expand synonym to other entities (database, linked server)