HaloDB 的 Oracle 兼容模式
↑ 关注“少安事务所”公众号,欢迎⭐收藏,不错过精彩内容~
前倾回顾
前面介绍了“光环”数据库的基本情况和安装办法。
-
哈喽,国产数据库!Halo DB! -
三步走,Halo DB 安装指引
★HaloDB是基于原生PG打造的新一代高性能安全自主可控全场景通用型统一数据库。 业内首次创造性的提出插件式内核架构设计,通过配置的方式,适配不同的应用场景,打造全场景覆盖的能力,满足企业大部分数据存储处理需求。从而消除数据孤岛,降低系统复杂度,保护企业既有投资,降低企业成本。同时支持x86、arm等异构平台之间的混合部署。
或许大家对 Halo DB 在 Oracle 和 MySQL 的兼容性支持方面也非常感兴趣。
本文将介绍如何开启 HaloDB 的 Oracle 兼容模式,以及基础使用方法。
HaloDB 的 Oracle 兼容模式
那么,HaloDB 到底兼容哪些 Oracle 语法、视图、系统包呢?
这里有一份(部分)清单,可供参考。
Halo 数据库支持 Oracle 兼容语法:
-
支持连接符 -
支持带别名的 UPDATE -
支持匿名子查询 -
支持窗口函数 DISTINCT 操作 -
支持 DUAL 伪表 -
支持 SYSDATE/SYSTIMESTAMP -
支持 ROWNUM -
支持 ROWID -
支持 MINUS 操作 -
支持 DECODE 函数(不限制参数个数) -
支持 DBLINK 语法 -
支持 Oracle 格式的数值输出 -
支持 VARCHAR2/NUMBER/CLOB/BLOB 数据类型 -
支持 START WITH/CONNECT BY 语法 -
支持 IN 的特别语法(例: SELECT * FROM a_table WHERE a IN b) -
支持 Oracle 格式的日期类型及运算 -
支持 LISTAGG/WM_CONCAT 函数 -
支持 HAVING/GROUP BY 子句顺序互换(即 HAVING 子句可在GROUP BY 之前也可在 GROUP BY 之后) -
支持 NULL 与空串的等价转换 -
支持 Oracle 语法的序列取值 -
支持 Oracle 语法的 PROCEDURE/FUNCTION/PACKAGE 的创建 -
支持 ORDER BY 子句中使用列别名 -
支持 TABLE 函数 -
支持 MERGE INTO 语法 -
支持 WITHIN GROUP 语法 -
支持 Q’ 转义语法 -
支持 NLS_DATE_FORMAT 参数 -
支持 Oracle 的常用视图
Halo 数据库支持 Oracle 兼容的视图:
-
DBA_SEGMENTS -
PRODUCT_COMPONENT_VERSION -
USER_CON_COLUMNS -
USER_CONSTRAINTS -
USER_IND_COLUMNS -
USER_OBJECTS -
USER_PROCEDURES -
USER_SOURCE -
USER_TAB_COLUMNS -
USER_TABLES
Halo 数据库支持 Oracle 兼容的系统包:
-
DBMS_ALERT -
DBMS_ASSERT -
DBMS_OBFUSCATION_TOOLKIT -
DBMS_OUTPUT -
DBMS_PIPE -
DBMS_RANDOM -
DBMS_UTILITY -
UTL_FILE -
UTL_I18N
等等。
清单很长,这里就不再列举了,详情可留言,带你进《HaloDB产品吐槽群》。
开启 HaloDB 的 Oracle 兼容模式
修改配置文件
如需开启 Oracle 兼容模式,需要先对数据库配置文件 postgresql.conf 进行调整。
#database_compat_mode = 'postgresql' --> database_compat_mode = 'oracle'
#standard_parserengine_auxiliary = 'on' --> standard_parserengine_auxiliary = 'on'
#transform_null_equals = off --> transform_null_equals = off
#oracle.use_datetime_as_date = false --> oracle.use_datetime_as_date = true
其中,
-
database_compat_mode
该参数表示:
该参数为枚举类型,表示数据库运行模式。
默认值为 postgresql,其它可取值包括 oracle 、 mysql 、 sybase 、 sqlserver 、 db2 等。
-
standard_parserengine_auxiliary
该参数表示:
是否需要标准编译引擎协同。默认值 on.
-
transform_null_equals
该参数表示:
由于针对NULL的任何操作都只会返回NULL,所以要判断一个值是否为NULL一般只能用IS NULL来判断。
Halo提供了参数 transform_null_equals 来控制是否可以用“=”操作符来判断一个值是否为NULL。
-
oracle.use_datetime_as_date
该参数表示:
Oracle 的 date 类型带有日期和时间信息,这和Halo的默认设置不同。
默认情况下,Halo的date类型只包含日期,datetime类型才包含日期和时间信息。
如果想要实现和Oracle相同的date类型,可以将参数use_datetime_as_date设置为true (默认值是 off)。
重启 Halo 数据库
pg_ctl restart
创建 Oracle 扩展
针对需要启用 Oracle 解析引擎的数据库创建 Oracle 扩展:
需要注意的是:如需采用 oracle 模式,新建库要创建扩展才能使用 oracle 语法。
create extension aux_oracle cascade;
查看已安装的扩展:
halo0root=# \dx
List of installed extensions
Name | Version | Schema | Description
------------+---------+--------------------+----------------------------------------------------
aux_init | 1.0 | information_schema | Init Supplementary Extension
aux_oracle | 1.8 | public | Halo Oracle Supplementary Extension
pgcrypto | 1.3 | public | cryptographic functions
plorasql | 1.0 | pg_catalog | Oracle Compatibal SQL (PL/SQL) procedural language
plpgsql | 1.0 | pg_catalog | PL/pgSQL procedural language
(5 rows)
测试 HaloDB 的 Oracle 兼容模式
1. 查看组件产品的版本和状态信息。
halo0root=# table product_component_version;
product | version | status
------------+--------------------+------------------
Halo 14.10 | 1.0.14.10 (231130) | 64bit Production
plpgsql | 1.0.14.10 (231130) | 64bit Production
aux_init | 1.0 | 64bit Production
plorasql | 1.0 | 64bit Production
pgcrypto | 1.3 | 64bit Production
aux_oracle | 1.8 | 64bit Production
(6 rows)
2. 测试 DBMS_ASSERT 系统包
该系统包用于对输入值的属性进行验证。
ENQUOTE_NAME 方法表示用双引号引用字符串,并检查其是否为合法的SQL标识符。
halo0root=# SELECT DBMS_ASSERT.ENQUOTE_NAME('Hello, HaloDB');
enquote_name
-----------------
"hello, halodb"
(1 row)
halo0root=# SELECT DBMS_ASSERT.ENQUOTE_NAME('Hello, HaloDB', false);
enquote_name
-----------------
"Hello, HaloDB"
(1 row)
3. 验证和Oracle相同的date类型
确认 oracle.use_datetime_as_date
参数已开启。
halo0root=# show oracle.use_datetime_as_date;
oracle.use_datetime_as_date
-----------------------------
on
(1 row)
验证步骤如下:
halo0root=# create table t (a date, b datetime);
CREATE TABLE
halo0root=# insert into t select now(),now();
INSERT 0 1
halo0root=# table t;
a | b
---------------------+---------------------
2024-05-28 12:09:11 | 2024-05-28 12:09:11
(1 row)
总结
到此,我们介绍了如何开启 HaloDB 的 Oracle 兼容模式,并做了简单验证。
如果你也对这款“光环”数据库感兴趣,欢迎转发、留言。
🌻 往期精彩 ▼
-
哈喽,国产数据库!Halo DB! -
从 PG 技术峰会南京站汲取的那些干货 -
PG 扩展推荐:pgpasswd & PG 密碼長度 -
即将告别PG 12,建议升级到PG 16.3版本 -
PG Style! 盘点几个常用的 Postgres 环境变量 -
后 EL 7 时代,PG 16 如何在 CentOS 7 上运行
-- / END / --

如果这篇文章为你带来了灵感或启发,就请帮忙点『赞』or『在看』or『转发』吧,感谢!(๑˃̵ᴗ˂̵)
本文由 mdnice 多平台发布
相关文章:

HaloDB 的 Oracle 兼容模式
↑ 关注“少安事务所”公众号,欢迎⭐收藏,不错过精彩内容~ 前倾回顾 前面介绍了“光环”数据库的基本情况和安装办法。 哈喽,国产数据库!Halo DB! 三步走,Halo DB 安装指引 ★ HaloDB是基于原生PG打造的新一代高性能安…...

【Python】解决Python报错:TypeError: ‘xxx‘ object does not support item assignment
🧑 博主简介:阿里巴巴嵌入式技术专家,深耕嵌入式人工智能领域,具备多年的嵌入式硬件产品研发管理经验。 📒 博客介绍:分享嵌入式开发领域的相关知识、经验、思考和感悟,欢迎关注。提供嵌入式方向…...

Spring-注解
Spring 注解分类 Spring 注解驱动模型 Spring 元注解 Documented Retention() Target() // 可以继承相关的属性 Inherited Repeatable()Spirng 模式注解 ComponentScan 原理 ClassPathScanningCandidateComponentProvider#findCandidateComponents public Set<BeanDefin…...

旧手机翻身成为办公利器——PalmDock的介绍也使用
旧手机有吧!!! 破电脑有吧!!! 那恭喜你,这篇文章可能对你有点用了。 介绍 这是一个旧手机废物利用变成工作利器的软件。可以在 Android 手机上快捷打开 windows 上的文件夹、文件、程序、命…...

期货交易的雷区
一、做自己看不懂的行情做交易计划一样要做有把握的,倘若你在盘中找机会交易,做自己看不懂的行情,即便你做进去了,建仓时也不会那么肯定,自然而然持仓也不自信,有点盈利就想平仓,亏损又想扛单。…...

东方通TongWeb结合Spring-Boot使用
一、概述 信创需要; 原状:原来的服务使用springboot框架,自带的web容器是tomcat,打成jar包启动; 需求:使用东方通tongweb来替换tomcat容器; 二、替换步骤 2.1 准备 获取到TongWeb7.0.E.6_P7嵌入版 这个文件,文件内容有相关对应的依赖包,可以根据需要来安装到本地…...

6.S081的Lab学习——Lab5: xv6 lazy page allocation
文章目录 前言一、Eliminate allocation from sbrk() (easy)解析: 二、Lazy allocation (moderate)解析: 三、Lazytests and Usertests (moderate)解析: 总结 前言 一个本硕双非的小菜鸡,备战24年秋招。打算尝试6.S081࿰…...

在WHM中如何调整max_post_size参数大小
今日我们在搭建新网站时需要调整一下PHP参数max_post_size 的大小,我们公司使用的Hostease的美国独立服务器产品默认5个IP地址,也购买了cPanel面板,因此联系Hostease的技术支持,寻求帮助了解到如何在WHM中调整PHP参数,…...

智能监控技术助力山林生态养鸡:打造智慧安全的养殖新模式
随着现代科技的不断发展,智能化、自动化的养殖方式逐渐受到广大养殖户的青睐。特别是在山林生态养鸡领域,智能化监控方案的引入不仅提高了养殖效率,更有助于保障鸡只的健康与安全。视频监控系统EasyCVR视频汇聚/安防监控视频管理平台在山林生…...

那些不起眼但很好玩的API合辑
那些不起眼但很好玩的API,为我们带来了许多出人意料的乐趣和惊喜。这些API可能看起来并不起眼,但它们却蕴含着无限的创意和趣味性。它们可以是一些小游戏API,让我们可以在闲暇时刻尽情娱乐;也可以是一些奇特的音乐API,…...

java —— 克隆对象、枚举
一、克隆对象 (一)在基本数据类型中,直接将对象 A 的值赋给对象 B,当更改对象 B 的时候,对象 A 的值保持不变。例如: public static void main(String[] args) {int a5;int ba; //将…...

STM32-GPIO八种输入输出模式
图片取自 江协科技 STM32入门教程-2023版 细致讲解 中文字幕 p5 【STM32入门教程-2023版 细致讲解 中文字幕】 https://www.bilibili.com/video/BV1th411z7sn/?p5&share_sourcecopy_web&vd_source327265f5c70f26411a53a9226af0b35c 目录 编辑 一.STM32的四种输…...

windows镜像虚拟机创建共享文件夹详细步骤 -- 和本地电脑传输文件
第一步:关闭客户机 第二步:右击“虚拟机名称”或菜单栏的“虚拟机”–>“设置” 网络适配器选择NAT或者其他的都可以 来到“选项”,启用共享文件夹,具体如下图:点击添加,添加主机文件夹。然后确定 第三步…...

通关!游戏设计之道Day18
过场动画,或者说根本没人看的东西 过场动画是一系列的动画或实时的动作序列,用来推进剧情制造大场面,烘托气氛,展示对话和角色成长,以及显现在某些情况下被玩家忽略的相关线索。 过场动画是一把双刃剑,一方…...

写Python时不用import,你会遭遇什么
from *** import *** 想必你已经再熟悉不过这样的python语法。 当你的 python 代码需要获取外部的一些功能(一些已经造好的轮子),你就需要使用到 import 这个声明关键字。import可以协助导入其他 module 。(类似 C 预约的 inclu…...

java网络:过滤器修改请求头
目录 一、gateway的全局过滤器 二、web的OncePerRequestFilter以及常见过滤器Filter 三、过滤器排序 一、gateway的全局过滤器 Component Slf4j public class GatewayAuthFilter implements GlobalFilter, Ordered {Overridepublic Mono<Void> filter(ServerWebExchan…...

yolov10 快速使用及训练
参考: https://docs.ultralytics.com/models/yolov10/ ultralytics其实大多数系列都能加载使用: 官方: https://github.com/THU-MIG/yolov10.git 代码参考: https://colab.research.google.com/github/roboflow-ai/notebooks/blob/main/notebooks/train-yolov10-object-…...

CSS变量 -- var() 使用教程
目录 1 CSS变量的基本使用1.1 变量定义1.1 变量使用1.3 全局/局部变量 2 CSS变量的参数3 CSS变量的拼接和计算3.1 拼接3.2 计算 4 JS 修改 CSS变量 CSS 自定义属性(有时候也被称作CSS 变量或者级联变量),它的值可以在整个文档中重复使用。 复…...

python基础-数据结构-leetcode刷题必看-queue---队列-python的底层构建
文章目录 队列双端队列 deque底层存储deque接口1. __init__(self, iterable: Iterable[_T], maxlen: int | None None) -> None2. append(self, __x: _T) -> None3. appendleft(self, __x: _T) -> None4. copy(self) -> Self5. count(self, __x: _T) -> int6. …...

深入理解Spring Security:保护你的Web应用程序
深入理解Spring Security:保护你的Web应用程序 这听起来像是一部詹姆斯邦德电影,邦德试图进入坏家伙的藏身之处。坏家伙设置了一系列超级安全措施,有多层次的安全防御。邦德克服了其中一层,进入了隐藏处,但又遇到了下一个陷阱。他战胜了一个又一个陷阱,最终克服了所有障…...

【车载开发系列】Vector工具链的安装
【车载开发系列】Vector工具链的安装 【车载开发系列】Vector工具链的安装 【车载开发系列】Vector工具链的安装一. VectorDriver二. DaVinci_Developer三. DaVinci Configurator 一. VectorDriver Vector Driver Setup是Vector产品链中重要的驱动软件,所有的硬件设备进行连接…...

Windows系统部署YOLOv5 v6.1版本的训练与推理环境保姆级教程
文章目录 一 概述二 依赖环境(prerequisites)2.1 硬件环境2.2 软件环境 三 环境安装3.1 创建并激活虚拟环境3.2 安装Pytorch与torchvision3.3 校验Pytorch安装3.4 下载 YOLOv5 v6.1 源码3.5 安装 YOLOv5 依赖3.6 下载预训练模型3.7 安装其他依赖3.8 测试环境安装3.9 测试训练流…...

[RK3588-Android12] 关于EDP屏外设为Panel,不支持HPD的配置
问题描述 直接附上dts配置,也可自行查看先关文档RKDocs\common\display\Rockchip_RK3588_User_Guide_eDP_CN.pdf 解决方案: // EDP屏参数panel-edp {compatible "simple-panel";// 屏en脚 自行根据原理图配置enable-gpios <&gpioX R…...

142.栈和队列:用栈实现队列(力扣)
题目描述 代码解决 class MyQueue { public:stack<int> stIn; // 输入栈,用于push操作stack<int> stOut; // 输出栈,用于pop和peek操作MyQueue() {}void push(int x) {stIn.push(x); // 将元素压入输入栈}int pop() {// 如果输出栈为空&…...

乡村振兴的乡村产业创新发展:培育乡村新兴产业,打造乡村产业新名片,促进乡村经济多元化发展
目录 一、引言 二、乡村产业创新发展的必要性 (一)适应新时代发展要求 (二)满足消费升级需求 (三)促进农民增收致富 三、培育乡村新兴产业策略 (一)加强科技创新引领 &#…...

数据库|基于T-SQL创建数据库
哈喽,你好啊,我是雷工! SQL Server用于操作数据库的编程语言为Transaction-SQL,简称T-SQL。 本节学习基于T-SQL创建数据库。以下为学习笔记。 01 打开新建查询 首先连接上数据库,点击【新建查询】打开新建查询窗口, …...

智能家居ZigBee网关选型定制指南:主控,操作系统,天线设计,助力IoT开发者
随着科技的发展和人们生活水平的提高,智能家居以其便捷、舒适、安全等特点,逐渐走进千家万户,成为家装消费品换新升级的重要方向。在智能家居系统中,网关扮演着中枢控制器的角色,负责将各种设备连接到互联网上…...

QT截图程序,可多屏幕截图二,增加调整截图区域功能
上一篇QT截图程序,可多屏幕截图只是实现了最基本的截图功能,虽然能用但是缺点也有,没办法更改选中的区域,这在实际使用时不太方便。这篇增加了这个功能。先看看效果。 实现代码为: 头文件 #ifndef MASKWIDGET_H #de…...

开源浪潮与闭源堡垒:大模型未来的双重奏
从数据隐私、商业应用和社区参与等方面来看,开源大模型和闭源大模型各有优劣势。开源模型在透明度、社区协作和成本效益方面具有优势,而闭源模型在安全性、合规性和商业竞争力方面表现出色。因此,我更倾向于认为,未来的大模型发展…...

postman教程-6-发送delete请求
领取资料,咨询答疑,请➕wei: June__Go 上一小节我们学习了postman发送put请求的方法,本小节我们讲解一下postman发送delete请求的方法。 HTTP DELETE 请求是一种用于删除指定资源的请求方法。在RESTful API 设计中,DELETE 请求…...