Oracle通过数据库链连接KingbaseES

news2024/11/19 18:33:35

测试环境:

ip数据库版本
192.168.254.135oracle 11g
192.168.254.137V008R006C005B0023

通过oracle官网得知,Oracle使用DG4ODBC作为连接到其他非Oracle数据库的数据网关。其原理图如下:
所以我们需要在Oracle服务器安装unixODBC和KingbaseES的ODBC驱动。

1.root用户登录到oracle数据库服务器。
2.安装unixODBC

yum install unixODBC.x86_64 注:unixODBC可能默认装系统的时候就已经安装上了。

[root@oracledb ~]# odbcinst -j
unixODBC 2.3.1
DRIVERS............: /etc/odbcinst.ini
SYSTEM DATA SOURCES: /etc/odbc.ini
FILE DATA SOURCES..: /etc/ODBCDataSources
USER DATA SOURCES..: /root/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8

注意:由于不同版本之间存在差异,为了保证能读取正确的配置,强烈建议统一使用用户主目录下 .odbc.ini 文件。

3.安装KingbaseES的ODBC驱动
KingbaseES 安装完成后在数据库安装目录下的 Interface/odbc 中就有odbc驱动,所以这里只要将文件拷贝到oracle主机上即可。scp 192.168.254.137://home/kingbase/kdb/Interface/odbc/* /usr/local/lib/
设置文件权限为755。chmod 755 /usr/local/lib/* 我的/usr/local/lib/目录原来是空目录,这里直接用*了。

4.配置ODBC

[root@oracledb lib]# cat /etc/odbcinst.ini 
# Example driver definitions

# Driver from the postgresql-odbc package
# Setup from the unixODBC package
[kdb]
Description     = ODBC for kingbase
Driver64        = /usr/local/lib/kdbodbcw.so
Setup64         = /usr/lib64/libodbcpsqlS.so
FileUsage       = 1

kdbodbcw.so是KingbaseES ODBC驱动的库。
libodbcpsqlS.so 是unixODBC的库。

[root@oracledb ~]# cat .odbc.ini 
[V8]
Description = kdb test
Driver = kdb
Database = test
Servername = 192.168.254.137
UserName = system
Password = system
Port = 54321
ReadOnly = 0
ConnSettings = set client_encoding to UTF8

这里Driver与odbcinst.ini中的[kdb]对应,可以取任何名字,但两者需要相同。
[V8]是一个自定义的连接数据库的配置名称,其它应用程序就是引用这个名称访问数据库。

5.验证ODBC连接

[root@oracledb ~]# isql -v V8                      
+---------------------------------------+
| Connected!                            |
|                                       |
| sql-statement                         |
| help [tablename]                      |
| quit                                  |
|                                       |
+---------------------------------------+
SQL> select version();
+--------------------------------------------------------------------------------------------------------------------------+
| version                                                                                                                                                                                                                                                                                                     |
+--------------------------------------------------------------------------------------------------------------------------+
| KingbaseES V008R006C005B0023 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46), 64-bit                                                                                                                                                                                        |
+--------------------------------------------------------------------------------------------------------------------------+
SQLRowCount returns 1
1 rows fetched

测试能够正常连接数据库并查询。
将.odbc.ini 配置文件拷贝一份到oracle用户的home目录下,确认文件属性是否正确。
下面来配置 oracle 透明网关部分,使用oracle用户来操作,共涉及3个文件。
$ORACLE_HOME/network/admin/listener.ora
$ORACLE_HOME/hs/admin/init<SID_NAME>.ora
$ORACLE_HOME/network/admin/tnsnames.ora
在 cd $ORACLE_HOME/hs/admin 目录下有 监听和tns配置的示例文件。
1.配置listener.ora

SID_LIST_LISTENER=
  (SID_LIST=
      (SID_DESC=
         (SID_NAME=KINGBASE)
         (ORACLE_HOME=/home/oracle/app/oracle/product/11.2.0/dbhome_1)
         (PROGRAM=dg4odbc)
      )
  )
在listener.ora文件中添加上面这段内容。
其中SID_LIST_LISTENER后面的这个LISTENER是监听器的名字,默认的都是这个。
SID_NAME=KINGBASE KINGBASE为自定义名称。这个名称将决定init<SID_NAME>.ora这个文件的名称(大小写要一致)

2.创建init<SID_NAME>.ora

cd $ORACLE_HOME/hs/admin/initKINGBASE.ora
根据监听的配置,这里创建initKINGBASE.ora
[oracle@oracledb admin]$ cat initKINGBASE.ora
HS_FDS_CONNECT_INFO = V8
HS_FDS_TRACE_LEVEL = 0
HS_FDS_SHAREABLE_NAME = /usr/local/lib/kdbodbcw.so
HS_NLS_NCHAR=UCS2
HS_LANGUAGE=AMERICAN_AMERICA.AL32UTF8
set ODBCINI= /home/oracle/.odbc.ini

3.配置 tnsnames.ora

KINGBASE  =
  (DESCRIPTION=
    (ADDRESS=(PROTOCOL=tcp)(HOST=localhost)(PORT=1521))
    (CONNECT_DATA=(SID=KINGBASE))
    (HS=OK)
  ) 

SID=KINGBASE 这个listener.ora文件中的sid设置一样。
第一行的KINGBASE = 可设置为任意名称,供后续创建数据库链时使用。

4.重启或者重载监听。
5.连接oracle创建数据库链,测试。create database link to_kingbase connect to "system" identified by "system" using 'KINGBASE';

在KingbaseES数据库中创建表并插入数据

在oracle数据库中进行查询

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/159571.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

4 位硬科技创始人对谈 DevOps 硬件实战

随着 DevOps 技术更为广泛地在各行各业应用&#xff0c;从公司层面来看&#xff0c;考察的不仅仅是 DevOps 平台的技术&#xff0c;更多的是 DevOps 平台与企业产品的兼容性与企业文化能否为 DevOps 提供落地的土壤&#xff0c;这背后是商业模式、思维方式、管理理念的一系列变…

【项目实战】一文讲解车企是如何做HTTPS双向认证的

一、背景 很多主机厂都说需要做HTTPS的双向认证&#xff0c;那到底什么是双向认证呢&#xff1f; 二、什么是Https的双向认证&#xff1f; 英文是Mutual TLS HTTPS双向认证是一种安全通信方式&#xff0c;它需要在客户端和服务端之间进行双向身份验证。在这种方式中&#x…

2.浅谈计算机系统(硬件+软件)。

一、现代计算机系统是由哪两部分组成的&#xff1f;1.什么是物联网&#xff1f;2.有些计算机是非常复杂的。二、计算机系统简介。计算机系统的构成&#xff08;硬件、软件&#xff09;。三、软件。1.系统软件。2.应用软件。思维导图是清菡本人所画。一、现代计算机系统是由哪两…

C#上位机基础学习_基于SOCKET实现与PLC服务器的TCP通信(一)

C#上位机基础学习_基于SOCKET实现与PLC服务器的TCP通信(一) 测试软件: TIA PORTAL V15.1 S7-PLCSIM ADVANCED V3.0 Visual Studio 2019 如下图所示,打开S7-PLCSIM ADVANCED V3.0仿真软件,新键一个实例,设置仿真PLC的IP地址等参数,然后点击Start激活PLC, 如下图所示,…

蓝牙耳机怎么连接电脑?无线耳机连接电脑的教程

想要减少噪音&#xff0c;更好地聆听音乐&#xff0c;或者是看电视&#xff0c;很多人都会选择戴耳机。其中蓝牙耳机成为越来越多人的选择&#xff0c;它方便携带&#xff0c;没有有线的缠绕。 可能有人会问&#xff1a;无线蓝牙耳机可以连接电脑吗&#xff1f;当然可以。可是…

【3 - 数据预处理】菜菜sklearn机器学习

课程地址&#xff1a;《菜菜的机器学习sklearn课堂》_哔哩哔哩_bilibili 第一期&#xff1a;sklearn入门 & 决策树在sklearn中的实现第二期&#xff1a;随机森林在sklearn中的实现第三期&#xff1a;sklearn中的数据预处理和特征工程第四期&#xff1a;sklearn中的降维算法…

前端使用xlsx-js-style导出Excel文件并修饰单元格样式

xlsx-js-style安装引入需要导出的数据源将数据源转成需要的二维数组定义 Excel 表头将定义好的表头添加到 body 中将二维数组转成 sheet!merges 设置单元格合并!cols 设置列宽!rows 设置行高创建虚拟的 workbook向 workbook 中添加 sheet导出 workbook完整示例效果图总结安装 …

elasticsearch实现简单的脚本排序(script sort)

文章目录1、背景2、分析3、构建数据3.1 mapping3.2 插入数据4、实现4.1 根据省升序排序4.1.1 dsl4.1.2 运行结果4.2 湖北省排第一4.2.1 dsl4.2.2 运行结果4.3 湖北省排第一&#xff0c;其余省升序排序&#xff0c;按照年龄倒序4.3.1 dsl4.3.2 java代码4.3.3 运行结果5、完整代码…

【自学Python】Python逻辑运算符

Python逻辑运算符 Python逻辑运算符教程 在 Python 中&#xff0c;逻辑运算符用于连接多个条件&#xff08;一般来讲就是关系表达式&#xff09;&#xff0c;最终的结果是一个 bool 值。Python 的逻辑运算符主要包括 and&#xff08;逻辑与&#xff09;、or&#xff08;逻辑或…

ArcGIS基础实验操作100例--实验88按距离分配空间

本实验专栏参考自汤国安教授《地理信息系统基础实验操作100例》一书 实验平台&#xff1a;ArcGIS 10.6 实验数据&#xff1a;请访问实验1&#xff08;传送门&#xff09; 空间分析篇--实验88 按距离分配空间 目录 一、实验背景 二、实验数据 三、实验步骤 &#xff08;1&am…

[白嫖]利用百度图片缓存规则作为图床

利用百度图片缓存规则作为图床先看一张图片&#xff1a;这张图片引用了百度的图片服务器&#xff1a;https://gimg2.baidu.com/image_search/srcpicx.zhimg.com/v2-a6f0db9230a0e4b67e70524217e009fe_1440w.jpg&app2020但实际上这张图片的源站在知乎&#xff1a;https://pi…

Nginx与LUA(2)

您好&#xff0c;我是湘王&#xff0c;这是我的CSDN博客&#xff0c;欢迎您来&#xff0c;欢迎您再来&#xff5e;除了反向代理&#xff0c;Nginx另一个主要的功能就是「负载均衡」。所谓负载均衡&#xff0c;就是将请求分摊到多个服务器上执行&#xff0c;从而减轻单台服务器的…

使用 ADManager Plus 管理Microsoft 365许可证

作为 Microsoft 365 管理员&#xff0c;管理用户的 Microsoft 365 许可证&#xff0c;为新员工分配适当的 Microsoft 365 许可证&#xff0c;在员工离开组织时释放 Microsoft 365 许可证&#xff0c;以及将释放的许可证重新分配给其他用户&#xff0c;构成了日常活动的重要组成…

YGG 在 Branch.gg 的免费游戏 Castaways 中购买了 Genesis NFT

YGG 在 Branch.gg 的第一款免费 web3 游戏 Castaways 中购买了 NFT 资产。Branch.gg 是一家开发开放世界沙盒大型多人在线游戏&#xff08;MMO&#xff09;的游戏初创公司&#xff0c;玩家通过合作来确保他们的生存。 在公开市场购买时&#xff0c;YGG 已经获得了 1,000 个 Cas…

ShareSDK 常见问题

QQ-分享报错901111&#xff0c;9001010等 由于QQ现在需要审核后才可以分享&#xff08;之前分享不需要审核&#xff09;&#xff0c;所以此错误解决方法只需通过腾讯开放平台的审核即可&#xff0c;另外要检查注册好的应用的基本信息&#xff0c;包名、md5签名和Bundle id是不…

上半年要完成的博客50

这里写自定义目录标题欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注…

C++ 优先级队列的vector实现

前段时间在研究Astar算法&#xff0c;里面涉及到几个重要的知识点&#xff0c;链表数据结构、优先队列数据结构&#xff0c;在以前的工作中没有接触到&#xff0c;学习后发现真是好东西&#xff0c;对C的认知更深了一步&#xff0c;不废话了&#xff0c;下面正文&#xff1a; …

【正点原子FPGA连载】第十一章U-Boot使用实验 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Linux开发指南

1&#xff09;实验平台&#xff1a;正点原子MPSoC开发板 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id692450874670 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第十一章U-Boot使…

ESP32接入米家-小爱同学-IDF环境-巴法平台

0 引言 冬天床边没有开关&#xff0c;睡觉懒得关灯&#xff0c;想通过小爱同学控制灯的开关&#xff0c;但是不想换开关。 所以 想用ESP32接入米家&#xff0c;控制一个舵机实现开关控制。 文章目录0 引言1 MQTT协议2 ESP32 MQTT例程2.1 ESP-MQTT 库2.2.1 配置结构体 esp_mqt…

【Python基础】字符串基本操作(切片、格式化、编码)

文章目录一. 字符串1.1 字符串切片操作1.2 格式化字符串1.2.1 内容填充1.2.2 宽度精度1.3 编码解码一. 字符串 1.1 字符串切片操作 字符串是不可变类型 不具备增、删、改操作切片操作将产生新的对象&#xff0c;但如果是相同的字符串&#xff0c;对象不变。 操作格式&#xf…