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

多模态2025:技术路线“神仙打架”,视频生成冲上云霄
文|魏琳华 编|王一粟 一场大会,聚集了中国多模态大模型的“半壁江山”。 智源大会2025为期两天的论坛中,汇集了学界、创业公司和大厂等三方的热门选手,关于多模态的集中讨论达到了前所未有的热度。其中,…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
现有的 Redis 分布式锁库(如 Redisson)提供了哪些便利?
现有的 Redis 分布式锁库(如 Redisson)相比于开发者自己基于 Redis 命令(如 SETNX, EXPIRE, DEL)手动实现分布式锁,提供了巨大的便利性和健壮性。主要体现在以下几个方面: 原子性保证 (Atomicity)ÿ…...
uniapp 字符包含的相关方法
在uniapp中,如果你想检查一个字符串是否包含另一个子字符串,你可以使用JavaScript中的includes()方法或者indexOf()方法。这两种方法都可以达到目的,但它们在处理方式和返回值上有所不同。 使用includes()方法 includes()方法用于判断一个字…...

通过MicroSip配置自己的freeswitch服务器进行调试记录
之前用docker安装的freeswitch的,启动是正常的, 但用下面的Microsip连接不上 主要原因有可能一下几个 1、通过下面命令可以看 [rootlocalhost default]# docker exec -it freeswitch fs_cli -x "sofia status profile internal"Name …...
c# 局部函数 定义、功能与示例
C# 局部函数:定义、功能与示例 1. 定义与功能 局部函数(Local Function)是嵌套在另一个方法内部的私有方法,仅在包含它的方法内可见。 • 作用:封装仅用于当前方法的逻辑,避免污染类作用域,提升…...
MFE(微前端) Module Federation:Webpack.config.js文件中每个属性的含义解释
以Module Federation 插件详为例,Webpack.config.js它可能的配置和含义如下: 前言 Module Federation 的Webpack.config.js核心配置包括: name filename(定义应用标识) remotes(引用远程模块࿰…...