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

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

csdh11 2025-03-07 17:51 2 浏览


不是每一款数据库都能全面兼容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功能如何实现故障下业务的快速恢复、如何做到全自动一键迁移等,敬请期待。

相关推荐

Hutool Java工具类库导出Excel,超级简单

作者:程序猿的内心独白原文链接:http://suo.im/5Zxx2L前言在开发应用系统的时候,导出文件是必不可放的功能。以前用过POI、easyexcel等工具的导入导出功能,但总感觉太麻烦了,代...

java轻松玩转Excel之EasyExcel

项目地址:https://github.com/PiKeZhao/excel-model.git如果您对该项目有什么问题加群咨询哦978219630(各类电子书籍,学习视频等)大家常用Apache...

程序员:超级简单导出Excel 工具,Hutool Java工具类库

前言在开发应用系统的时候,导出文件是必不可放的功能。以前用过POI、easyexcel等工具的导入导出功能,但总感觉太麻烦了,代码特别多,感觉并不是很好用。今天给大家介绍一款新工具,java工具类库H...

EasyExcel导出Excel表格到浏览器,通过Postman测试导出Excel

一、前言小编最近接到一个导出Excel的需求,需求还是很简单的,只需要把表格展示的信息导出成Excel就可以了,也没有复杂的合并列什么的。...

好难~记录一次生产上的OOM解决过程

点击上方,轻松关注!及时获取有趣有料的技术文章记录一次生产上的OOM解决过程一.项目架构...

发现开源:替换Jenkins,支持多用户多语言部署平台Walle很震撼

溪云阁:专注编程教学,架构,JAVA,Python,微服务,机器学习等领域,欢迎关注,一起学习。部署系统,从手动部署,到用jenkins,到阿里的自动化运维部署,一直在不断的变化姿势,好让自己舒服点。...

SpringBoot + EasyExcel 轻松实现百万级数据导入导出,用起来还优雅

01、背景介绍在实际的业务系统开发过程中,操作Excel实现数据的导入导出基本上是个非常常见的需求。...

10W 行级别数据的 Excel 导入优化记录

优质文章,及时送达作者:后青春期的Keatswww.cnblogs.com/keatsCoder/p/13217561.html需求说明项目中有一个Excel导入的需求:缴费记录导入...

easypoi导出Excel根据内容如何自动换行和自动调整行高

在使用easypoi导出EXCEL的时候,经常会遇到需要根据内容自动换行和自动调整行高的情况...

POI读取/生成Excel大文件,有高人吗?

最近在搞一个通用文件处理服务器,需要处理excel文件,但是有的excel文件大小超过3M,读取文件时直接导致jvm异常:gcoverheadlimitexceeded。原来poi读取excel...

如何轻松实现Excel动态列导出?Easypoi教程来袭!

EasyPoi简介EasyPoi是一款基于ApachePOI和jxls的Java开源框架,它可以用于快速创建Excel、Word、Pdf等复杂文档。Easypoi最大的特点是可以通过注解来实现对Ex...

Excel导出,Excel模板导出Excel导入,Word模板导出神器-Easypoi

概述Easypoi是码云上的一个开源项目。项目开发组织是Lemur开源。目前属于码云最有价值开源项目。Easypoi是对poi的封装,其主打的功能就是容易,让一个没见接触过poi的人员就可以方便...

优雅地实现EasyPoi动态导出列的两种方式

前言嗨,大家好,我是希留。...

easypoi一款方便快捷的excel处理框架,赶紧学习起来

easypoi是一个基于ApachePOI和jxls封装的Java框架,用于简化Excel导入导出和Word导出等操作。它支持将Java对象转换为Excel或Word文档,并支持Excel模板导出和...

EasyPoi使用

EasyPoi的主要特点:1.设计精巧,使用简单2.接口丰富,扩展简单3.默认值多,writelessdomore4.springmvc支持,web导出可以简单明了使用1.easypoi...