欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

Sqlserver创建连接MySql的链接服务器

程序员文章站 2022-06-08 08:45:51
...

第一步 :在MySql服务器上安装与系统对应的 MySql-Connector-ODBC 官方下载地址 安装过程中可能会报 缺失 msvcr100.dll 的错误,这需要你根据系统到网上下载对应的这个dll文件。(当初遇到这个问题的时候,在网上试了很多的这种文件 最后才找到一个合适自己

第一步:在MySql服务器上安装与系统对应的 MySql-Connector-ODBC

官方下载地址

安装过程中可能会报 缺失 msvcr100.dll 的错误,这需要你根据系统到网上下载对应的这个dll文件。(当初遇到这个问题的时候,在网上试了很多的这种文件 最后才找到一个合适自己的)

如果换了几个这个dll还是无法解决,可以考虑下载安装一个较低一点的版本 (当初我尝试5.3.4失败了一上午,结果换成5.1 一路顺畅)

第二步:设置MySql Connector

控制面板-管理工具-数据源(ODBC),在【ODBC 数据源管理器】的【系统DSN】中点击【添加】

在弹出的窗口中如下图填写

Sqlserver创建连接MySql的链接服务器

其中 Test 是该数据源的命名,在之后才会用到

TCP/IP Server即当前服务器的IP,Port不用修改

User和Password就是数据库的账号密码

Database就是想要建立连接的数据库

填完之后,点击【Test】 如果弹出连接成功,则表示可成功创建。

注意:测试连接情况的时候,可能会报出【Host 'XXX' is not allowed to connect to this MySQL server】

这是因为MySQL没有开启远程访问权限。

解决方案可以参考这篇文章【戳这里】

第三步:创建链接服务器

exec sp_addlinkedserver 
 @server='Test',       --这是之前创建MySql Connector时的data source name
 @srvproduct='MyConnector',    --这个随便
 @provider='MSDASQL',    --这是固定的
 @datasrc=NULL,
 @location=NULL,
 @provstr='Driver={MySQL ODBC 5.3 ANSI Driver};Server=115.11.111.11;Database=myDatabase;User=root;Password=mypassword;Option=3;',  --连接字符串
 @catalog = NULL
go
exec sp_addlinkedsrvlogin 
  @rmtsrvname='Test',
  @useself='false',
  @rmtuser='root',
  @rmtpassword='mypassword';
GO

这个比较简单,至于连接字符串,这有个在线生成器

第四步:测试连接及使用

测试连接方式如下图

Sqlserver创建连接MySql的链接服务器Sqlserver创建连接MySql的链接服务器

链接服务器的使用

主要是利用函数OpenQuery

SELECT * FROM OPENQUERY (Test ,'select * from Table001')

UPDATE OPENQUERY (Test , 'SELECT name FROM Table001 WHERE id = 1') 
SET name = 'ADifferentName'

INSERT OPENQUERY (Test , 'SELECT name FROM Table001')
VALUES ('sss')

DELETE OPENQUERY (Test , 'SELECT name FROM Table001 WHERE name = ''sss''')

其中Test是创建的链接服务器的名字