Recently I got a project in which there was a Migration Task to be done from MYSql to SQL Server. Prior to this I never worked in MySQL and I thought it would be just simple as creating LinkedServer to mySQL and pull the data to SQL Server from SQL Server itself. So I decided to create linked server from SQL Server to My SQL and pull the data using OPENQuery Function. I tried to configure linked server in SQL Server and then realized that it is not simple as that. I had to lot of steps like download driver, install it , configure the provider etc. As usual I searched in net and found a thread which neatly mentioned the steps (
SQLServerCentral.com). This thread really solved my problem in hours. Of course the thread was good enough for an expert (indirect way of saying that am an expert ), but for a newbie it may be bit confusing. So I thought to make a comprehensive document which has all the step by step screen shots so that the process will be easier. Having said that, I am not taking any credit for this document, the whole credit goes to Jim Dillon who posted his solution in the above mentioned site.
Tested Environment :Operating System : Windows XP, Windows 2000, Windows 2003
SQL Server : SQL Server 2005, (Note : I have not tested SQL Server 2000 but I feel it should work)
MySQL : MySQL Server 5.0
MySQL ODBC : ODBC 3.51
High level Steps• Download and Install ODBC Driver from MYSQL Site
• Create ODBC DSN
• Create Linked Server in SQL Server
• Configure Provider
• Create linked server
• Enable OpenQuery in SQL Server instance
• Create Openquery script
Step 1 : Download MySQL ODBC ConnectorDownload MySQL Connector/ODBC 3.51 from :
http://dev.mysql.com/downloads/connector/odbc/3.51.htmlDownload the ODBC connector for your Operating System. I have windows xp , so I will download Windows MSI installer (x86)
Step 2 : Install ODBC connector Double click the downloaded file
data:image/s3,"s3://crabby-images/46347/46347e396af3db51eef3252d25e743b1c0777c60" alt=""
data:image/s3,"s3://crabby-images/6d038/6d03843f497b1c77b3de8b63a6fb68284c68fa74" alt=""
data:image/s3,"s3://crabby-images/cb246/cb246141de4b4e37532615d2edc14199130137d5" alt=""
At last screen you will get a Finish button and click that. Now You have installed ODBC connector for MySQL.Step 3 : Create System DSN for MYSql ODBC DriverWindows Start --- >> Run --- >> odbcad32
Or
Windows Start --- >> Control Panel ->Performance and Maintenance (in XP) --- >> Administrative Tools -> Data Sources (ODBC)
data:image/s3,"s3://crabby-images/5d865/5d86529dc307a63eeea8ed8a6fdd263b69ff17af" alt=""
data:image/s3,"s3://crabby-images/a2bb0/a2bb0dae945956f336345d7cd5c7fcd20e522439" alt=""
data:image/s3,"s3://crabby-images/0b486/0b48658cbb39ff6cf2c1ea8378685fccde631d19" alt=""
data:image/s3,"s3://crabby-images/e7be1/e7be1b77e72dba7af9ea8db93b3959c55d513c67" alt=""
data:image/s3,"s3://crabby-images/52fe5/52fe5ae559e496d544093e58623bd8a65acef95f" alt=""
data:image/s3,"s3://crabby-images/c88ee/c88eeecbd7111442151c0b4c182dcda8c3211951" alt=""
data:image/s3,"s3://crabby-images/e30f5/e30f519ac3d81530cc12cd658932058c74a8fe87" alt=""
data:image/s3,"s3://crabby-images/e5f8c/e5f8c6be0ba7dc730f3ef98ce1656424cc7da1b0" alt=""
Step 3 : Create Linked Server in SQL Server 2005.Change the properties of the ProviderSelect the properties as shown in the screens
data:image/s3,"s3://crabby-images/b94ff/b94ff30b17a72eeba3cd67ac8e2d27862f151c95" alt=""
data:image/s3,"s3://crabby-images/1a42b/1a42b2b32798080029bca415f3b111d3cb58879e" alt=""
data:image/s3,"s3://crabby-images/61201/612018c24d4b3196db2e970b98236554d677ea4f" alt=""
--======================================================================================================
Script to Create Linked Server
It is always better to create linked server using Script than GUI. You have more control and script of course is more readable. I am not giving the screen shot for this steps. Copy paste the script to a query analyzer change DSN Name, Username, Password and run.--======================================================================================================
/****** Object: LinkedServer [LinkedServerTOMySQL] Script Date: 08/28/2008 11:40:28 ******/
EXEC master.dbo.sp_addlinkedserver
@server = N'LinkedServerTOMySQL',
@srvproduct=N'MySQLDatabase',
@provider=N'MSDASQL',
@datasrc=N'MYSQLODBCConnection'
Parameter Explanation
@server = N'LinkedServerTOMySQL', -- Linked server name (it can be anything)
@srvproduct=N'MySQLDatabase', -- Keep as it is
@provider=N'MSDASQL', -- Keep as it is
@datasrc=N'MYSQLODBCConnection' --DSN Name Created in Step 3 (very important)
/* For security reasons the linked server remote logins password is changed with ######## */
EXEC master.dbo.sp_addlinkedsrvlogin
@rmtsrvname=N'LinkedServerTOMySQL',
@useself=N'False',
@locallogin=NULL,
@rmtuser=N'root',
@rmtpassword='change thepasswordhere'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'collation compatible', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'data access', @optvalue=N'true'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'dist', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'pub', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'rpc', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'rpc out', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'sub', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'connect timeout', @optvalue=N'0'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'collation name', @optvalue=null
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'lazy schema validation', @optvalue=N'false'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'query timeout', @optvalue=N'0'
GO
EXEC master.dbo.sp_serveroption @server=N'LinkedServerTOMySQL', @optname=N'use remote collation', @optvalue=N'true'
--======================================================================================================
Enable Distributed Queries (OpenQuery) in SQL Instance By default in SQL Server 2005 Distributed Queries are disabled. You have to enable it using the following script. (
Note : In SQL Server 2000 no need to run this script)
Copy this script to a query analyzer and run EXEC sys.sp_configure N'show advanced options', N'1' RECONFIGURE WITH OVERRIDE
EXEC sys.sp_configure N'Ad Hoc Distributed Queries', N'1'
RECONFIGURE WITH OVERRIDE
Finally, Test the Linked Server and Run a OpenQuer against the LinkedServer ConfiguredCheck the following Screen
data:image/s3,"s3://crabby-images/4dd88/4dd8880f559b727fb08e3d720a8a84b86da1bdb4" alt=""
Restart Database Engine and SQL Server AgentOnce you have completed all the steps you may restart the services. I have not tested this whether you need to restart it or not
Summary : If anyone feels some screen shots are missing please drop a comment.