MSSQL2008 64位 ODBC问题
MSSQL2008 64位的环境,
安装了mysql-connector-odbc-5.1.8-win64.msi,
但在SQL中无法找到 odbc的数据源。
运行:odbcad32.exe,可以看到已经成功安装了驱动。
------解决方案--------------------MSSQL2008 64位的环境,
安装了mysql-connector-odbc-5.1.8-win64.msi,
楼主是MSSQL环境,可是为什么要装MYSQL的。。。
------解决方案--------------------
------解决方案--------------------
------解决方案--------------------SQL code
SQLSERVER连接MYSQL 建立链接如下:
数据库软件与ODBC软件:mysql- 5.1.50-win32与ODBC5·1(注意,odbc3.1版本,会出现乱码)
MYSQL数据库情况:gmp_test
第一步:先要在MYSQL进行授权,让主机能访问MYSQL数据库,设置如下:
在mysql数据库执行,语句:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.216' IDENTIFIED BY 'yxtech' WITH GRANT
第二步:在SQLSERVER主机,设置ODBC连接,建立的是MYSQL的数据源:
第三步:在SQL SERVER 配置连接,配置语句如下
--删除连接
exec sp_dropserver 'dxmysql','droplogins'
--建立一个新连接
EXEC SP_ADDLINKEDSERVER
@server = 'dxmysql', --连接名称(随意,规范就可)
@srvproduct = 'MYSQL', --连接MYSQL,数据库类型,固定的
@provider = 'MSDASQL', --连接MYSQL的编码,固定的
@datasrc = 'my_sql' --建立的ODBC连接(第二步建立的)
--建立用户连接
EXEC sp_addlinkedsrvlogin 'dxmysql','false','bi_etl','root','yxtech'
--'dxmysql'为连接名称
--'bi_etl'为SQLSERVER用户,如果为NULL
--'root','yxtech' 为登录MYSQL 的用户及密码
--进行查询
select * FROM OPENQUERY(dxmysql, 'select * from test1')
------解决方案--------------------
------解决方案--------------------
楼主有没有执行第一步,去进行授权!
------解决方案--------------------
你要创建连接啊!
EXEC SP_ADDLINKEDSERVER
@server = 'dxmysql', --连接名称(随意,规范就可)
@srvproduct = 'MYSQL', --连接MYSQL,数据库类型,固定的
@provider = 'MSDASQL', --连接MYSQL的编码,固定的
@datasrc = 'my_sql' --建立的ODBC连接(第二步建立的)
这儿名称对不对?
------解决方案--------------------
如果用MYODBC 的DSN的话,请进入ODBC配置栏, 将flag中有return matching rows 这项 打勾
如果用MYODBC的连接字符串,请将OPTION值 加 2
"driver={MySQL ODBC 3.51 driver},server=xxx,db=xxx,uid=xxx,pwd=xxx,option=3"
(备注,每个选项对应option一个值,如1,2,4,8..., 选中某个就加某个值)
你可能是用DSN.
http://zhidao.baidu.com/question/61206261.html
http://www.yesky.com/imagesnew/software/mysql/manual_ODBC.html