【小白专用】Sql Server 连接Mysql 更新23.12.09

news/2024/7/23 10:27:33 标签: mysql, 数据库

目标

已知mysql连接参数(地址和用户),期望通过Microsoft Sql Server Management Studio (以下简称MSSSMS)连接Mysql,在MSSSMS中直接查询或修改Mysql中的数据。


一般是选最新的版本下载。
选64位还是32位,要保证和你的sqlserver版本一致,利用下面sql查看:

一、下载mysql的odbc驱动

mysqlcomdownloadsconnectorodbc_1">1、官方下载包

二、安装mysql odbc

双击msi文件即可安装,安装步骤如下:

(三)配置ODBC

打开ODBC,添加数据源驱动程序,配置MySQL链接

2.1、搜索odbc,用管理员身份运行:

2.1 控制面板→管理工具→ODBC数据源(64位)→双击打开

2.2 添加msql odbc数据源

点击系统DSN→添加→MySQL ODBC x.1 Unicode Driver

点击完成后,跳出mysql链接页面

Data Source Name:数据源名称
Decription:描述,随便写
Server:MYSQL服务器的IP
Port:MYSQL的端口,默认的是3306.可以改的.
User:连接账号(在mysql上授权的账号,同时给予相应权限)
Password:密码

Database:选择链接的数据库
 

2.3测试添加是否成功

填上mysql的基本信息,点击Test提示成功即可点击ok

五 、打开!SQL Server Management Studio

右键添加链接服务器

5.1 常规

链接服务器:可自定义取名,用于后面调用访问
数据源为odbc的名称,如这里,如这里我应该填写MYSQL

5.2 密码

填写mysql的用户和密码,点击确定,无任何报错即可。

经过上面两步,就可以连接成功了,连接成功是没有成功窗口的。

服务器下面能看到连接名且下面有数据库就算成功连接。

--创建链接服务器  更新2023.12.09 11:30


--创建链接服务器
EXEC sp_addlinkedserver @server = 'MYSQLTEST', @srvproduct='MySqlTest',@provider = 'MSDASQL',@datasrc ='MYSQL'
 
--删除链接服务器
execute sys.sp_dropserver @server='MYSQLTEST'


--其中的 @server = 'MYSQLTEST'指自定义的服务名,@srvproduct='MySqlTest'自己随便 ,@provider='MSDASQL'固定这个, @datasrc ='MYSQL'  是指 ODBC中的数据源名称。

执行语句

刷新对象资源管理器中的链接服务器,能看到的Connector ODBC里面填的data source name内容,目录下对应的是mysql里的数据库

六、linkedserver查询语句

6.1 利用OPENQUERY访问

--linkedserver查询语句 利用OPENQUERY访问 更新2023.12.09 11:30


-- MYSQLTEST为链接服务器名称
-- 里面的select需要使用''引起来,并且如果寻找where条件的字符还需要再添加一次引号
select * from openquery(MYSQLTEST,'select * from user ')

select * from openquery(MYSQLTEST,'select * from user where User = ''root''')

(此处OPENQUERY函数相当于是一个表名,你在SQL SERVER中可以对其进行增删改查的操作。此处好像只能增删改查,别的就不行了,请高手指教一下)

openquery解释:
对给定的链接服务器执行指定的传递查询。该服务器是 OLE DB 数据源。OPENQUERY 可以在查询的 FROM 子句中引用,就好像它是一个表名 。OPENQUERY 也可以作为 INSERT、UPDATE 或 DELETE的语句的目标
表进行引用。但这要取决 于 OLE DB 访问接口的功能。尽管查询可能返回
多个结果集,但是 OPENQUERY 只返回第一个。
OPENQUERY(linked_server,’query’)
Linked_server表示链接服务器名称的标识符。‘query’为查询语句
 

----------------------

附件 

- linkedserver可能报错问题

如果上面连接linkedserver时可能报如下错误:

解决办法:

  1. 新增用户名并分配权限
  2. 需要对root账户做些操作,这个方法不建议,就不做解释了。


http://www.niftyadmin.cn/n/5249583.html

相关文章

UNDERSTANDING AND IMPROVING INFORMATION TRANSFER IN MULTI-TASK LEARNING

Z i _i i​ X i R i X_iR_i Xi​Ri​, X X X是Task embedding layers, R R R是Alignment matrices 辅助信息 作者未提供代码

Nacos源码解读08——集群节点间的健康检查

集群间的节点健康检查 引言 1.当集群间 新加入一个节点或者宕掉一个节点时其他节点怎么感知这个节点的操作的 2.当节点宕机之后 又是怎么做剔除的 3.新加入一个节点怎么让集群其他成员感知到 带着这些问题来看下面的代码 服务健康检查 在ServerMemberManager容器启动 的时候…

LeetCode 每日一题 2023/12/4-2023/12/10

记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 12/4 1038. 从二叉搜索树到更大和树12/5 2477. 到达首都的最少油耗12/6 2646. 最小化旅行的价格总和12/7 1466. 重新规划路线12/8 2008. 出租车的最大盈利12/9 2048. 下一个…

clickhouse优化汇总

记录下clickhouse平常用到的几个优化点: 1.数据类型的选择,不要都把每一列都设置成字符串类型,并且对于枚举值很少的字符串类型,可以使用LowCardinality编码,使用整数代替字符串存储 2.字段类型最好不要运行为null&…

朝花夕拾华山平台流水账

2021年8月25日,我加入了诚迈科技(南京),加入了华山平台。 跟我一起入职平台的还有三个小伙伴:小帅、小阳、小甘。 小帅能力很强,前后端都会,入职各种考试工具人。 小阳毕业没多久,一…

Kubernetes - 为什么 K8S 在容器里不能调用自己?

问题描述 最近遇到一个神奇的现象,在 K8S 的 POD 容器中,比如 pod name:mini-appnamespace:devport:5050 那么,是无法在 mini-app 容器里执行以下命令,如果执行,会一直卡在这条命…

【Docker】进阶之路:(一)容器技术发展史

【Docker】进阶之路:(一)容器技术发展史 什么是容器为什么需要容器容器技术的发展历程Docker容器是如何工作的 什么是容器 容器作为一种先进的虚拟化技术,已然成为了云原生时代软件开发和运维的标准基础设施。在了解容器技术之前…

ubuntu22.04 安装cuda

CUDA(Compute Unified Device Architecture)是由 NVIDIA 开发的一种并行计算平台和编程模型。它允许开发者利用 NVIDIA 的 GPU(图形处理单元)进行高效的计算处理。CUDA 通过提供一系列的 C、C 和 Fortran 扩展,使得开发…