百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

不是所有牛奶都叫特仑苏 不是所有大数据都能玩转K-DB

mhr18 2024-10-09 12:18 21 浏览 0 评论


不是每一款数据库都能全面兼容Oracle,就像不是所有数据库都可以被称之为K-DB,一般数据库能做到的SQL标准和函数上兼容Oracle,而K-DB则能实现更多,在数据库体系架构、集群方式、数据库对象、函数与存储过程、数据库运维工具、管理与调优方法以及OCI 等方面都全面兼容Oracle。

限于文章篇幅,本文先从体系架构、逻辑结构、数据对象、数据类型、SQL支持、函数、数据库工具和数据备份恢复这八个方面详细阐述K-DB是如何实现对Oracle(以Oracle 11g为主)的全面兼容。

体系架构

从下图体系架构对比可以看出,K-DB在数据库进程的管理模式、内存管理模式、REDO/UNDO/ARCHIVE日志管理模式、备份恢复方式、基于共享存储的Active-Active集群等方面,有着跟Oracle类似的实现方式,同时具备了Oracle数据库提供的诸如RAC、ASM、严格行级锁、MVCC等企业级复杂功能。

K-DB体系架构Oracle体系架构
üMulti-Process +Multi-ThreadüREDO/UNDO、Archive日志ü基于共享存储的Active-Active的KRACü严格的行级锁、多版本控制MVCCüRange、List、Hash、Composite分区ü星型转换、位图索引、自定义聚集函数ü虚拟存储技术KASü多节点并行恢复üMulti-ProcessüREDO/UNDO、Archive日志ü基于共享存储的Active-Active的RACü严格的行级锁、多版本控制MVCCüRange、List、Hash、Composite分区ü星型转换、位图索引、自定义聚集函数ü虚拟存储技术ASM

逻辑结构

K-DB提供了典型的数据库(Database)、表空间(Tablespace)、段(Segment)、区(Extent)、数据块(DB Block)的逻辑结构,以及逻辑结构与物理数据文件的对应关系,也都跟Oracle类似。

数据对象

K-DB支持的数据库对象(Object)主要包括:表(Table)、索引(Index)、视图(View)、Sequence、Synonym、触发器(Trigger)、存储过程、权限管理、函数(Function)、Package等,不仅如此在用户需要的情况下,K-DB还支持基于用户创建的函数和组件。

功能K-DB Oracle
Table支持支持
Composite Index支持支持
View支持支持
Sequence支持支持
Database Link支持支持
Synonym支持支持
权限管理支持支持
Role支持支持
Procedure支持支持
Stored Function支持支持
Package支持支持
Trigger支持支持

数据类型

K-DB支持Oracle的字符串类型、数字类型、日期类型、LOB等所有类型,也支持ANSI标准类型。

区分数据类型OracleK-DB
字符串类型CHAR, VCHAR2, NCHAR, NVACHAR2, LONG支持支持
数字类型NUMBER支持支持
日期类型DATE, TIME, TIMESTAMP,INTERVAL YEAR TO MONTH,INTERVAL DAY TO SECOND,TIMESTAMP WITH TIME ZONE,TIMESTAMP WITH LOCAL TIME ZONE支持支持
其他RAW, LONG RAW,CLOB, BLOB, NCLOB,ROWID, XMLTYPE支持支持
ANSI 数据类型CHAR, CHARACTER, CHAR VARYING…NUMERIC, DECIMAL, INT, INTEGER 等支持支持
Object类型User Defined Type支持支持

SQL支持

K-DB不仅支持 ANSI标准 SQL语法,还支持 Oracle非标准语法,从而实现了对于原有应用的方便迁移,提升了用户的便利性。

Object内容OracleK-DB
JoinEqui, Anti, Semi, Self,Cartesian, Inner, Outer, (+)支持支持
SubqueryIn-Line View, Nested Query支持支持
条件语句ANY, SOME, ALL, BETWEEN,EXISTS, IN, NULL, LIKE, REGEXP_LIKE支持支持
聚集运算子INTERSECT, UNION, UNION ALL,MINUS, EXCEPT支持支持
Group函数GROUP BY, HAVING, SELECT DISTINCT,GROUPING, GROUPING SETS支持支持
分析函数OVER (PARTITION BY ~ OERDER BY ~ROWS BETWEEN ~ AND ~)支持支持
一致性Read Committed(default),Select for update, Serializable支持支持
其他层次型函数 (Start with ~ Connect by ~)并行 DML (Insert Into ~ Select ~)Dual Table, CALL, Merge,Create Table As Select ~支持支持

函数

K-DB支持 200多个内建函数,并与 Oracle函数名称保持一致,包括:Math Function、String Function、DATE Function、Compare Function、Convert Function、Encode/Decode Function、Large Object Function、Analyze Function等,从而提升了用户的使用便利性。

这里只对Math Function做展示,更多详情可下载完整白皮书了解。

Math Function

Oracle K-DBOracle K-DB
ABSABSLOG(N,M)LOG(N,M)
ACOSACOSMODMOD
ASINASINPOWERPOWER
ATANATANROUNDROUND
ATAN2ATAN2SIGNSIGN
AVGAVGSINSIN
BITANDBITANDSINHSINH
CEILCEILSQRTSQRT
COSCOSTANTAN
COSHCOSHTANHTANH
COUNTCOUNTTRUNCTRUNC
EXPEXPOracle KDB
FLOORFLOORLOG(N,M)LOG(N,M)
LNLNMODMOD

数据库工具

K-DB提供全面的数据库自动化工具,包括管理工具kdAdmin、导出/导入工具kdExport/kdImport、迁移工具kdMigrator、快速装载工具kdLoader、调优工具等,极大方便了开发人员和管理员进行数据库开发和运维管理。

K-DB与Oracle提供的Tool对比

功能KDBOracle
GUI Admin ToolkdAdmin OEM
Interactive SQL 执行器kdSQLSQLPlus
Data LoaderkdLoaderSQL*Loader
Export/ImportkdExport/kdImportExport/Import
Migration ToolkdMigrator, tableMigratorOracle Migration WorkBench
C Pre-compilerkdpcproc
Auto Trace支持支持
Explain Plan支持支持
SQL Trace & tkprof支持支持

备份与恢复

K-DB支持多种备份与恢复功能,包括表空间级别的在线备份与恢复功能、基于“RMGR”工具的增量备份功能等。从而保证了 DBMS的稳定运行。

功能内容OracleK-DB
备份Online(Hot) Backup支持支持
Offline(Cold) Backup支持支持
Table Export/Import支持支持
Incremental Backup支持支持
恢复完全恢复支持支持
不完全恢复 – 基于时间支持支持
不完全恢复 – 基于 SCN支持支持
在 Online状态下进行数据文件恢复支持支持
Block level recovery支持支持
Flashback Query支持支持
Flashback Table支持支持
Flashback Version Query支持支持
Flashback Transaction Query支持支持
Flashback Database支持支持

相同中的不同:

除了以上说的,K-DB在架构用语、权限控制、Schema管理、JOB Scheduler、优化器、集群方式等也能全面兼容Oracle。

如需了解更多详情,请下载《K-DB全面兼容Oracle技术白皮书》

说了这么多相同,其实K-DB全面兼容Oracle数据库的同时,也有其自身的特性,比如:

ü采用Multi-Process、Multi-Thread架构,同时进程数量轻量化处理,整合集成管理进程,最终实现比Multi-Process更高效的资源利用;

ü多节点并行恢复机制,实现在因维护或故障需要而暂时关闭节点再重启时,K-DB支持在多个节点中同时执行恢复操作,大幅缩短恢复大量数据的时间;

ü新增异步I/O(AIO)功能,在Thread Level中将收集Dirty(已修改的)Block的操作和写入磁盘的操作区分为Gather Thread和异步 I/O Thread,从而有效的执行异步I/O。

小结

K-DB数据库和Oracle的全面兼容,能够最小限度降低迁移过程中程序的修改量,通过系统化工具主动地识别与诊断,解决数据库各层面兼容性问题。而且,K-DB的操作命令和界面使用上与Oracle相近, DBA在Oracle上积累的技术经验仍然可以应用于K-DB,操作不需要做出太大改变。

其实,K-DB的特点还有很多,将在后续的文章中继续讨论KRAC功能如何实现故障下业务的快速恢复、如何做到全自动一键迁移等,敬请期待。

相关推荐

甲骨文签署多项大型云协议,其一未来可贡献超300亿美元年收入

IT之家7月1日消息,根据甲骨文Oracle当地时间6月30日向美国证券交易委员会(SEC)递交的FORM8-K文件,该企业在始于2025年6月1日的202...

甲骨文获TEMU巨额合同,后者大部分基础设施将迁移至Oracle云

IT之家6月23日消息,Oracle甲骨文创始人、董事长兼首席技术官LarryEllison(拉里埃里森)在本月早些时候的2025财年第四财季和全财年财报电话会议上表示,Oracle...

Spring Boot 自定义数据源设置,这些坑你踩过吗?

你在使用SpringBoot进行后端开发的过程中,是不是也遇到过这样的问题:项目上线后,数据库连接总是不稳定,偶尔还会出现数据读取缓慢的情况,严重影响了用户体验。经过排查,发现很大一部分原因竟然...

一个开箱即用的代码生成器(一个开箱即用的代码生成器是什么)

今天给大家推荐一个好用的代码生成器,名为renren-generator,该项目附带前端页面,可以很方便的选择我们所需要生成代码的表。首先我们通过git工具克隆下来代码(地址见文末),导入idea。...

低代码建模平台-数据挖掘平台(低代码平台的实现方式)

现在来看一下数据连接。·这里是管理数据连接的空间,点击这里可以新增一个数据连接。·输入连接名称,然后输入url,是通过gdbc的方式去连接的数据库,目前是支持mysql、oracle以及国产数据库达梦...

navicat 17.2.7连接oracle数据库提示加载oracle库失败

系统:macOS15.5navicat版本:navicatpremiumlite17.2.7连接oracle测试报错:加载oracle库失败【解决办法】:放达里面找到程序,显示简介里面勾选“使...

开源“Windows”ReactOS更新:支持全屏应用

IT之家6月17日消息,ReactOS团队昨日(6月16日)在X平台发布系列推文,公布了该系统的最新进展,包括升级Explorer组件,支持全屏应用,从Wine项目引入了...

SSL 推出采用全模拟内置混音技术的模拟调音台Oracle

英国调音台传奇品牌SolidStateLogic宣布推出Oracle——一款采用全模拟内置混音技术的调音台,在紧凑的AWS尺寸机箱内集成了大型调音台的功能。该调音台提供24输入和...

47道网络工程师常见面试题,看看有没有你不会的!

你们好,我的网工朋友。网络工程师面试的时候,都会被问到什么?这个问题其实很泛,一般来说,你肯定要先看明白岗位需求写的是什么。基本上都是围绕公司需要的业务去问的。但不可否认的是,那些最基础的概念,多少也...

汉得信息:发布EBS系统安装启用JWS的高效解决方案

e公司讯,从汉得信息获悉,近日,微软官方宣布InternetExplorer桌面应用程序将于2022年6月15日正式停用。目前大部分客户都是使用IE浏览器打开EBS的Form界面,IE停用后,只能使...

36.9K star ! 推荐一个酷炫低代码开发平台!功能太强!

前言最近在逛github,看看能不能搜罗到一些对自己有帮助的开源软件。不经意间看到一个高star的java开源项目:jeecg-boot。进入在线演示版一看,感叹实在是太牛了!此开源项目不管是给来学习...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

手把手教你在嵌入式设备中使用SQLite3

摘要:数据库是用来存储和管理数据的专用软件,使得管理数据更加安全,方便和高效。数据库对数据的管理的基本单位是表(table),在嵌入式linux中有时候它也需要用到数据库,听起来好难,其实就是几个函数...

JAVA语言基础(java语言基础知识)

一、计算机的基本概念什么是计算机?计算机(Computer)全称:电子计算机,俗称电脑。是一种能够按照程序运行、自动高速处理海量数据的现代化智能电子设备。由硬件和软件组成、没有安装过任何软件的计算机称...

再见 Navicat!一款开源的 Web 数据库管理工具!

大家好,我是Java陈序员。在日常的开发工作中,常常需要与各种数据库打交道。而为了提高工作效率,常常会使用一些可视化工具进行操作数据库。今天,给大家介绍一款开源的数据库管理工具,无需下载安装软件,基...

取消回复欢迎 发表评论: