[Oracle-> MySQL] Oracle通过dblink连接MySQL--Oracle 19c pdb连接到MySQL 5.7
更多理论参考: http://blog.itpub.net/26736162/viewspace-2144661/
版本信息:
Oracle: 19.2.0.0.0 OS: CentOS 7.3
MySQL: 5.7.19 OS: CentOS 6.5
1)判断32位还是64位
[oracle@raclhr-18c-n1 ~]$ file $ORACLE_HOME/bin/dg4odbc
/u01/app/oracle/product/19.2.0/dbhome_1/bin/dg4odbc: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=4675eeb874fe889b960a29d3d084f9c1f4c471d0, not stripped
[oracle@raclhr-18c-n1 ~]$ ll
2)下载并安装ODBC Driver Manager
下载地址: http://www.unixodbc.org/download.html
可以在我的云盘或QQ群下载,或者点击文件:
unixODBC-2.3.7.tar.gz
解压并进行编译安装:
tar -zxvf unixODBC-2.3.7.tar.gz
cd /home/oracle/unixODBC-2.3.7
./configure --prefix=/usr/local/unixODBC-2.3.7 --includedir=/usr/include --libdir=/usr/lib -bindir=/usr/bin --sysconfdir=/etc
make && make install
安装成功后,unixODBC所需的头文件都被安装到了/usr/inlucde下,编译好的库文件安装到了/usr/lib下,与unixODBC相关的可执行文件安装到了/usr/bin下,配置文件放到了/etc下。
3)下载并按照ODBC Driver for MySQL
下载地址 : http://dev.mysql.com/downloads/connector/odbc/5.2.html#downloads
可以在我的云盘或QQ群下载,或者点击文件:
mysql-connector-odbc-5.3.13-1.el7.x86_64.zip
进行安装:
[root@raclhr-18c-n1 oracle]# rpm -ivh mysql-connector-odbc-5.3.13-1.el7.x86_64.rpm
warning: mysql-connector-odbc-5.3.13-1.el7.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
Preparing... ################################# [100%]
Updating / installing...
1:mysql-connector-odbc-5.3.13-1.el7################################# [100%]
Success: Usage count is 1
Success: Usage count is 1
4)配置ODBC Driver
vi /etc/odbc.ini
[myodbc5]
Driver = /usr/lib64/libmyodbc5w.so
Description = Connector/ODBC 5.2 Driver DSN
SERVER = 192.168.59.159
PORT = 3306
USER = root
PASSWORD = lhr
DATABASE = LHRDB
OPTION = 0
TRACE = OFF
5)验证ODBC连接
export ODBCINI=/etc/odbc.ini
isql myodbc5 -v
[root@raclhr-18c-n1 unixODBC-2.3.7]# which isql
/usr/bin/isql
[root@raclhr-18c-n1 unixODBC-2.3.7]# isql myodbc5 -v
+---------------------------------------+
| Connected! |
| |
| sql-statement |
| help [tablename] |
| quit |
| |
+---------------------------------------+
SQL> show databases;
+-----------------------------------------------------------------+
| Database |
+-----------------------------------------------------------------+
| information_schema |
| LHRDB |
| db_name |
| db_name2 |
| lhrdb |
| lhrdb2 |
| mysql |
| performance_schema |
| sakila |
| sys |
| test |
+-----------------------------------------------------------------+
SQLRowCount returns 11
11 rows fetched
mysql准备数据:
[root@LHRDB ~]# mysql -h192.168.59.159 -uroot -plhr
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 14
Server version: 5.7.19 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases
-> ;
+--------------------+
| Database |
+--------------------+
| information_schema |
| LHRDB |
| db_name |
| db_name2 |
| lhrdb |
| lhrdb2 |
| mysql |
| performance_schema |
| sakila |
| sys |
| test |
+--------------------+
11 rows in set (0.00 sec)
mysql> use LHRDB;
Database changed
mysql> show tables;
Empty set (0.00 sec)
mysql> create table lhrtest(id int);
Query OK, 0 rows affected (0.09 sec)
mysql> insert into lhrtest values(1);
Query OK, 1 row affected (0.00 sec)
mysql> select count(1) from lhrtest;
+----------+
| count(1) |
+----------+
| 1 |
+----------+
1 row in set (0.00 sec)
6)配置tnsnames.ora
myodbc5 =
(DESCRIPTION=
(ADDRESS=
(PROTOCOL=TCP) (HOST=192.168.59.52) (PORT=1521)
)
(CONNECT_DATA=
(SID=myodbc5)
)
(HS=OK)
)
7)配置listener.ora
SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(SID_NAME=myodbc5)
(ORACLE_HOME=/u01/app/oracle/product/19.2.0/dbhome_1)
(PROGRAM=dg4odbc)
(ENVS=LD_LIBRARY_PATH=/usr/lib:/u01/app/oracle/product/19.2.0/dbhome_1/lib)
)
)
8)创建 init.ora文件
创建文件$ORACLE_HOME/hs/admin/initmyodbc5.ora,内容如下:
vi $ORACLE_HOME/hs/admin/initmyodbc5.ora
HS_FDS_CONNECT_INFO=myodbc5
HS_FDS_SHAREABLE_NAME=/usr/lib/libodbc.so
HS_FDS_SUPPORT_STATISTICS=FALSE
HS_LANGUAGE=AMERICAN_AMERICA.WE8ISO8859P15
9)使上述配置文件生效, 验证配置是否正确
lsnrctl reload
lsnrctl status
tnsping myodbc5
[oracle@raclhr-18c-n1 unixODBC-2.3.7]$ odbcinst -j
unixODBC 2.3.1
DRIVERS............: /etc/odbcinst.ini
SYSTEM DATA SOURCES: /etc/odbc.ini
FILE DATA SOURCES..: /etc/ODBCDataSources
USER DATA SOURCES..: /home/oracle/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8
10)创建dblink并验证
create public database link mysqltest connect to "root" identified by "lhr" using 'myodbc5' ;
select count(*) from "lhrtest"@mysqltest;
[oracle@raclhr-18c-n1 admin]$ sas
SQL*Plus: Release 19.0.0.0.0 - Production on Sat May 11 22:13:20 2019
Version 19.2.0.0.0
Copyright (c) 1982, 2018, Oracle. All rights reserved.
Connected to:
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.2.0.0.0
SQL> show pdbs
CON_ID CON_NAME OPEN MODE RESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLY NO
3 LHRPDB2 READ WRITE NO
SQL> alter session set container=lhrpdb2;
Session altered.
SQL> create public database link mysqltest connect to "root" identified by "lhr" using 'myodbc5' ;
Database link created.
SQL> select count(*) from "lhrtest"@mysqltest;
COUNT(*)
----------
1
SQL> select * from "lhrtest"@mysqltest;
id
----------
1
SQL> insert into "lhrtest"@mysqltest values(2) ;
1 row created.
SQL> commit;
Commit complete.
mysql中查询:
mysql> select * from LHRDB.lhrtest;
+------+
| id |
+------+
| 1 |
| 2 |
+------+
2 rows in set (0.00 sec)
About Me
........................................................................................................................ ● 本文作者:小麦苗,部分内容整理自网络,若有侵权请联系小麦苗删除 ● 本文在itpub( http://blog.itpub.net/26736162 )、博客园( http://www.cnblogs.com/lhrbest )和个人weixin公众号( xiaomaimiaolhr )上有同步更新 ● 本文itpub地址: http://blog.itpub.net/26736162 ● 本文博客园地址: http://www.cnblogs.com/lhrbest ● 本文pdf版、个人简介及小麦苗云盘地址: http://blog.itpub.net/26736162/viewspace-1624453/ ● 数据库笔试面试题库及解答: http://blog.itpub.net/26736162/viewspace-2134706/ ● DBA宝典今日头条号地址: http://www.toutiao.com/c/user/6401772890/#mid=1564638659405826 ........................................................................................................................ ● QQ群号: 230161599 (满) 、618766405 ● weixin群:可加我weixin,我拉大家进群,非诚勿扰 ● 联系我请加QQ好友 ( 646634621 ) ,注明添加缘由 ● 于 2019-05-01 06:00 ~ 2019-05-30 24:00 在魔都完成 ● 最新修改时间:2019-05-01 06:00 ~ 2019-05-30 24:00 ● 文章内容来源于小麦苗的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解 ● 版权所有,欢迎分享本文,转载请保留出处 ........................................................................................................................ ● 小麦苗的微店 : https://weidian.com/s/793741433?wfr=c&ifr=shopdetail ● 小麦苗出版的数据库类丛书 : http://blog.itpub.net/26736162/viewspace-2142121/ ● 小麦苗OCP、OCM、高可用网络班 : http://blog.itpub.net/26736162/viewspace-2148098/ ● 小麦苗腾讯课堂主页 : https://lhr.ke.qq.com/ ........................................................................................................................ 使用 weixin客户端 扫描下面的二维码来关注小麦苗的weixin公众号( xiaomaimiaolhr )及QQ群(DBA宝典)、添加小麦苗weixin, 学习最实用的数据库技术。
........................................................................................................................ |
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26736162/viewspace-2644037/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/26736162/viewspace-2644037/