当前位置: 首页 > web >正文

【金仓数据库产品体验官】KingbaseES-ORACLE兼容版快速体验

不知不觉中,社区活动之金仓数据库产品体验官第三期开始了,本次在介绍产品体验的同时也希望感兴趣的朋友们一起来参加:

关于活动发起者:金仓社区

     金仓社区通常不是一个单一的论坛,而是一个由多个平台和渠道组成的综合体,主要包含以下几大部分:

     1、问答中心:用户遇到问题时可以在此提问,由金仓的技术支持工程师、资深用户或社区专家进行解答。这是解决问题、交流故障排除经验最重要的地方。

     2、知识库/技术文章:包含大量的官方技术文档、白皮书、最佳实践、迁移案例、性能优化技巧等高质量内容,是系统学习金仓数据库的宝库。

   3、产品资料下载:提供最新版本的数据库安装包、驱动(JDBC/ODBC等)、迁移工具、管理工具等资源的下载。

活动公告:发布线上/线下的技术沙龙、培训、大赛、技术分享直播等活动信息。

附一张社区首页截图:

体验官活动参加地址:(https://bbs.kingbase.com.cn/forumDetail?articleId=8a3fc929b40be1e5b6ad5bca3c9da3f9)我们继续来看下金仓数据库的ORACLE兼容模式:

    金仓数据库(KingbaseES)是北京人大金仓信息技术股份有限公司推出的国产大型通用关系型数据库,其 Oracle 兼容版 是其最重要的产品形态之一,核心目标是为使用 Oracle 数据库的用户提供一套平滑、低风险、高性能的国产化迁移替代方案。

该版本并非简单的“仿制”,而是基于深度兼容的理念进行设计和开发。

    其核心思想是:让原有的 Oracle 应用系统,能够以最小的修改代价(甚至零修改)迁移到金仓数据库上运行,从而极大地降低数据库国产化替代的技术风险、成本和时间周期。

    本文将深入探讨金仓数据库对ORACLE的兼容特性,通过实际测试体验其兼容程度,为考虑数据库迁移或国产化替代的企业提供参考。话不多说,我们接下来开启体验之旅:

开启体验之旅

首先进行下载ORACLE 兼容版本安装包:

下载地址:(https://www.kingbase.com.cn/download.html)

PS:下载安装包的同时,记得下载授权文件哦。

一、安装部署KingbaseES

查看Kingbase支持的OS版本:

KingbaseES支持各种主流的Linux操作系统64位发行版本,包括CentOS、中标麒麟、银河麒麟、统信UOS、Deepin、凝思、中科方德、欧拉等操作系统。

本次使用OS版本及配置:

1、新建kingbase用户

安装前必须创建 kingbase 用户,禁止使用 root 用户安装数据库。

创建用户所在的组:

groupadd dinstall -g 2001

创建用户:

useradd  -G dinstall -m -d /home/kingbase -s /bin/bash -u 2001 kingbase

修改用户密码:

passwd kingbase

2、配置内核参数

cat >> /etc/sysctl.conf<<OEF

fs.aio-max-nr= 1048576

fs.file-max= 6815744

kernel.shmall= 2097152

kernel.shmmax= 4294967295

kernel.shmmni= 4096

kernel.sem= 250 32000 100 128

net.ipv4.ip_local_port_range= 9000 65500

net.core.rmem_default= 262144

net.core.rmem_max= 4194304

net.core.wmem_default= 262144

net.core.wmem_max= 1048576

EOF

#生效配置

sysctl -p

3、修改文件打开最大数在 Linux、Solaris、AIX 和 HP-UNIX 等系统中,操作系统默认会对程序使用资源进行限制。如果不取消对应的限制,则数据库的性能将会受到影响。

#设置永久生效:

vi /etc/security/limits.conf

# *表示所有用户,可只设置root和kingbase用户

* soft nofile 65536

# 注意:设置nofile的hard limit不能大于/proc/sys/fs/nr_open,否则注销后将无法正常登陆

* hard nofile 65535

* soft nproc 65536

* hard nproc 65535

# unlimited表示无限制

* soft core unlimited

* hard core unlimited

登录Kingbase用户验证是否生效:

4、RemoveIPC参数

systemd-logind服务中引入的一个特性,是当一个用户退出系统后,会删除所有有关的IPC对象。该特性由/etc/systemd/logind.conf文件中的RemoveIPC参数控制。某些操作系统会默认打开,会造成程序信号丢失等问题(只有redhat7及以上和一些特殊的国产Linux的版本需要修改,改之前可先查看此项是否为默认yes)。设置RemoveIPC=no。 设置后重启服务:

systemctl daemon-reload

systemctl restart systemd-logind.service

5、创建目录并授权

mkdir /data/kdb

chown -R kingbase:kingbase /data/kdb

6、设置环境变量:

cat >>~/.bash_profile<<EOF

export PATH=/data/kdb/V9/Server/bin:$PATH

export KINGBASE_DATA=/data/kdb/V9/data

EOF

二、安装部署KingbaseES ORACLE兼容版

1、挂载镜像

切换到 root 用户,将 KingbaseES 数据库的 iso 安装包保存在任意位置

 cd  /data/soft

mount KingbaseES_V009R002C012B0003_Lin64_install.iso /mnt

2、命令行安装

切换至 kingbase 用户下,在 /mnt 目录下使用命令行安装数据库程序,依次执行以下命令安装 DM 数据库

su - kingbase

cd /mnt

开始进行一步步回车安装,中间篇幅太长,就先省略了。。。

看到Complate,表示安装已完成。

4、将KES服务注册为Linux系统服务

/data/kdb/install/script/root.sh

注册到Linux系统 进行使服务可以开机自启

登录验证连接:

三、开始进行功能体验

1. 测试 yminterval (年月至月间隔)和 dsinterval (天至秒间隔)数据类型

官方文档介绍:

开始测试:

测试间隔类型的运算

如上可以得出KingbaseES成功支持了yminterval和dsinterval数据类型。

2. 虚拟列测试

虚拟列(Virtual Column)是一种特殊的列,其值是根据其他列的值通过表达式计算得到的,而不直接存储在数据库中。虚拟列可以节省存储空间、保持数据一致性,并简化查询操作。

通过上边得结果可以看到,更新了基础列之后,虚拟列也会自动更新。PS:官方对GENERATED ALWAYS AS ..... STORED语法解释

3. 伪列测试(使用ROWNUM)

说明伪列测试也是正常支持的。

4. 分区表及interval自动分裂

说明Kingbase oracle兼容模式支持分区表以及interval自动分裂。

5、INTO子句与USING子句测试

创建测试基础表:

可以得到正常的返回说明是正常支持的。

6、RETURNING ... INTO 语句,及EXECUTE IMMEDIATE

达到预期效果,说明是正常支持的。

7、函数及数组测试

达到预期效果,说明是正常支持的。

8、LATERAL连接测试

达到预期效果,说明是正常支持的。

9、使用ARRAY_AGG和循环批量处理

达到预期效果,说明是正常支持的。

10、临时表测试

达到预期效果,说明是正常支持的。

总结

经过如上体验我们可以得知:

金仓数据库Oracle兼容模式基础语法支持良好:大多数基础DML,DDL语句与Oracle高度兼容,

同时PL/SQL高度兼容性(存储过程和函数: PL/SQL语法基本兼容),带来了非常棒的体验,

常见数据类型和基础函数能够正常工作,提供了非常好的兼容性,大大降低了从Oracle迁移至金仓数据库的技术门槛,

平滑迁移:极大减少了代码改写量,缩短了迁移周期,降低了项目风险。

期待金仓对Oracle的兼容性将进一步提升,为数据库国产化替代提供更加平滑的迁移路径。

http://www.xdnf.cn/news/19313.html

相关文章:

  • 深入理解drv_spi.c后,完全正向亲手移植rt-thread的drv_spi.c驱动 (基于stm32h750 artpi)
  • Java函数式编程之【流(Stream)性能优化】
  • WPF和WinFrom区别
  • 计算机毕设 java 阿歹果园养鸡场管理系统 基于 SSM 框架的果园养鸡场全流程管理系统设计与实现 Java+MySQL 的养殖生产与进销存一体化平台开发
  • 汽车专卖店管理系统的设计与实现(代码+数据库+LW)
  • Langflow核心技术学习笔记
  • 探索 XGBoost 与 LightGBM 的差异:哪个更适合你的项目?
  • 基于TCN-BiLSTM-SelfAttention神经网络的多输入单输出回归预测【MATLAB】
  • 力扣(LeetCode) ——645. 错误的集合(C语言)
  • 整体设计 的语言设计:通用模型语言的标准模板语言的规格模式语言(搜狗汪仔答问)
  • GooglePlay提审问题记录
  • 国家统计局数据分析01——机器学习
  • wpf之附加属性
  • Odoo与Django 的区别是什么?
  • ADFS 和 OAuth 的区别
  • 龙迅#LT7641GX适用于四路HDMI2.1/DP/TPYE-C转HDMI2.1混切应用,分辨率高达8K60HZ!
  • 线性表和顺序表
  • 数据存储——数据库
  • 安卓开发---SimpleAdapter
  • ansible的playbook练习题
  • shell学习(二)
  • 【完整源码+数据集+部署教程】传送带建筑材料识别系统源码和数据集:改进yolo11-AFPN-P345
  • 网站酷炫换皮肤?——PC 端 H5 换肤方案实战分享
  • PCIe 6.0 TLP结构解析:深入理解事务层数据包的设计与实现
  • IDEA编译报错:Error:(3, 28) java: 程序包com.alibaba.fastjson不存在
  • 图解帕累托前沿(pareto frontier)
  • 海康相机开发---设备布防(Setup Alarm)
  • python 解码 视频解码
  • RAG教程6:cohere rerank重排
  • openEuler系统实现MySQL数据库主从复制