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

全兼容Oracle?扒一扒浪潮K-DB是如何实现的?

haoteby 2025-02-06 14:55 12 浏览

“如果说Linux是类Unix操作系统,那么K-DB就是类Oracle数据库。会Unix的人,上手Linux要多少时间,则Oracle DBA上手K-DB就要多少时间。”以上观点来自一位参加了8月30日ITPUB组织的浪潮K-DB体验日活动DBA。

自从浪潮发布K-DB以来,不少文章都提到了K-DB与Oracle高兼容的特点,当然高兼容性也不可避免的带来了模仿与山寨之争,社交平台上对于K-DB的抨击措辞激烈,在老鱼看来这不过是一孔之见。原厂都不着急,我们急什么?相反高兼容对Oracle DBA来说,至少是利好,这意味着Oracle DBA所学所会,能继续发挥价值,有了更为广泛的应用领域。

言归正传,K-DB与Oracle高兼容的具体体现,目前网上还没有那篇文章有过系统的描述,不过就在昨天,浪潮正式发布了《K-DB全面兼容Oracle技术白皮书》,基于此白皮书,今天老鱼就给大家扒一扒K-DB是如何实现对Oracle全兼容的。

不少对标Oracle的数据库产品都号称兼容Oracle,但所谓的兼容实际上仅仅是SQL标准和函数上兼容Oracle。而K-DB却不限于此,不仅是SQL标准和函数上兼容Oracle,而且在数据库体系架构、集群方式、数据库对象、函数与存储过程、数据库运维工具、管理与调优方法以及OCI等方面都全面兼容Oracle。

下面将详细阐述K-DB是如何实现对Oracle(以Oracle 11g为主)的全面兼容:

一、数据库体系架构

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

二、架构用语

K-DB除了从数据库体系架构采用了与Oracle类似的实现方式之外,还提供了近乎一一对应地架构用语(如下表所示):

三、逻辑结构

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

2.3?1K-DB逻辑结构

四、Schema管理

K-DB支持用于Schema管理的多种功能与命令。

五、目录结构

K-DB与 Oracle相仿,在 Home Directory(%KD_HOME% 或 $KD_HOME)下存在 Server Engine 执行File Directory(bin)、Client程序 Directory(client)、设定 File Directory (config)、 DB Instance信息 Directory(instance) 以及包含各种 Database Script的 Directory(scripts)。具体的安装目录结构对比如下所示:

K-DB数据库主要的物理文件包括有:控制文件、数据文件、联机重做日志文件、参数文件、备份文件、归档日志文件、口令文件、预警和跟踪日志文件等,跟Oracle数据库的物理文件基本一致,并且使用方法类似。

六、数据库对象

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

可见,K-DB数据库对象跟Oracle数据库的对象类似,下表给出K-DB 与Oracle 所提供的数据库对象的对应情况。

七、数据类型

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

八、权限控制

与Oracle相仿,K-DB提供用户User、角色Role、权限的访问控制管理模式,并由此支持基于访问权限的数据库接入控制及用户访问与操作信息监控功能,从而保证数据库的安全运行。

九、SQL支持

K-DB不仅支持 ANSI标准 SQL语法,还支持 Oracle非标准语法。

十、函数

K-DB支持 200多个内建函数,并与 Oracle函数名称保持一致,包括:Math Function、String Function、DATE Function、Compare Function、Convert Function、Encode/Decode Function、Large Object Function、Analyze Function等。这里只对Math Function做展示,更多详情可下载完整白皮书了解。

表格1 Math Function

十一、JOB Scheduler

K-DB的DBMS_JOB Package提供定时执行用户指定 Stored Procedure的 Package,提供与 Oracle DBMS_JOB Package类似的使用方法与选项。

十二、优化器

K-DB提供基于CBO的优化器,多种 Hint及快速的统计信息创建性能。

十三、数据库工具

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

十四、备份与恢复

K-DB支持多种备份与恢复功能,包括表空间级别的在线备份与恢复功能、基于“RMGR”工具的增量备份功能等。

十五、高可用与高性能

K-DB 与Oracle 高可用性功能特点对比情况,如下表所示。

十六、安全

K-DB支持符合金融行业安全政策的访问控制、审计、加密等功能。

如需了解更多详情,请访问老鱼笔记下载:《K-DB全面兼容Oracle技术白皮书》。

相关推荐

如何随时清理浏览器缓存_清理浏览器缓存怎么弄

想随时清理浏览器缓存吗?Cookieformac版是Macos上一款浏览器缓存清理工具,所有的浏览器Cookie,本地存储数据,HTML5数据库,FlashCookie,Silverlight,...

Luminati代理动态IP教程指南配置代理VMLogin中文版反指纹浏览器

介绍如何使用在VMLogin中文版设置Luminati代理。首先下载VMLogin中文版反指纹浏览器(https://cn.vmlogin.com)对于刚接触Luminati动态ip的朋友,是不是不懂...

mac清除工具分享,解除您在安全方面的后顾之忧

想要永久的安全的处理掉重要数据,删除是之一,使用今天小编分享的mac清除工具,为您的操作再增一层“保护”,小伙伴慎用哟,一旦使用就不可以恢复咯,来吧一起看看吧~mac清除工具分享,解除您在安全方面的后...

取代cookie的网站追踪技术:”帆布指纹识别”

【前言】一般情况下,网站或者广告联盟都会非常想要一种技术方式可以在网络上精确定位到每一个个体,这样可以通过收集这些个体的数据,通过分析后更加精准的去推送广告(精准化营销)或其他有针对性的一些活动。Co...

辅助上网为啥会被抛弃 曲奇(Cookie)虽甜但有毒

近期有个小新闻,大概很多小伙伴都没有注意到,那就是谷歌Chrome浏览器要弃用Cookie了!说到Cookie功能,很多小伙伴大概觉得不怎么熟悉,有可能还不如前一段时间被弃用的Flash“出名”,但它...

浏览器指纹是什么?浏览器指纹包括哪些信息

本文关键词:浏览器指纹、指纹浏览器、浏览器指纹信息、指纹浏览器原理什么是浏览器指纹?浏览器指纹是指浏览器的各种信息,当我们访问其他网站时,即使是在匿名的模式下,这些信息也可以帮助网站识别我们的身份。...

那些通用清除软件不曾注意的秘密_清理不常用的应用软件

系统清理就像卫生检查前的大扫除,即使你使出吃奶的劲儿把一切可能的地方都打扫过,还会留下边边角角的遗漏。随着大家电脑安全意识的提高,越来越多的朋友开始关注自己的电脑安全,也知道安装360系列软件来"武装...

「网络安全宣传周」这些安全上网小知识你要知道!

小布说:互联网改变了人们的衣食住行,但与之伴生的网络安全威胁也不容忽视。近些年来,风靡全球的勒索病毒、时有发生的电信诈骗、防不胜防的个人信息泄露时时刻刻都威胁着我们的生活。9月18日-24日是第四届...

TypeScript 终极初学者指南_typescript 进阶

在过去的几年里TypeScript变得越来越流行,现在许多工作都要求开发人员了解TypeScript...

jQuery知识一览_jquery的认识和使用

一、概览jQuery官网:https://jquery.com/jQuery是一个高效、轻量并且功能丰富的js库。核心在于查询query。...

我的第一个Electron应用_electronmy

hello,好久不见,最近笔者花了几天时间入门Electron,然后做了一个非常简单的应用,本文就来给各位分享一下过程,Electron大佬请随意~笔者开源了一个Web思维导图,虽然借助showSav...

HTML5 之拖放(Drag 和 Drop)_html拖放api

简介拖放是一种常见的特性,即抓取对象以后拖到另一个位置。在HTML5中,拖放是标准的一部分,任何元素都能够拖放。先点击一个小例子:在用户开始拖动<p>元素时执行JavaScrip...

如何用JavaScript判断输入值是数字还是字母?

在日常开发中,我们有时候需要判断用户输入的是数字还是字母。本文将介绍如何用JavaScript实现这一功能。检查输入值是否是数字或字母...

图形编辑器开发:快捷键的管理_图形编辑工具

大家好,我是前端西瓜哥。...

浏览器原生剪贴板:原来它能这样读取用户截图!

当我们使用GitHub时,会发现Ctrl+V就能直接读取用户剪贴板图片进行粘贴,那么它是如何工作的?安全性如何?...