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应用程序 这听起来像是一部詹姆斯邦德电影,邦德试图进入坏家伙的藏身之处。坏家伙设置了一系列超级安全措施,有多层次的安全防御。邦德克服了其中一层,进入了隐藏处,但又遇到了下一个陷阱。他战胜了一个又一个陷阱,最终克服了所有障…...
Unity3D中Gfx.WaitForPresent优化方案
前言 在Unity中,Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染(即CPU被阻塞),这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案: 对惹,这里有一个游戏开发交流小组&…...
Qt Widget类解析与代码注释
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...
汽车生产虚拟实训中的技能提升与生产优化
在制造业蓬勃发展的大背景下,虚拟教学实训宛如一颗璀璨的新星,正发挥着不可或缺且日益凸显的关键作用,源源不断地为企业的稳健前行与创新发展注入磅礴强大的动力。就以汽车制造企业这一极具代表性的行业主体为例,汽车生产线上各类…...
ETLCloud可能遇到的问题有哪些?常见坑位解析
数据集成平台ETLCloud,主要用于支持数据的抽取(Extract)、转换(Transform)和加载(Load)过程。提供了一个简洁直观的界面,以便用户可以在不同的数据源之间轻松地进行数据迁移和转换。…...
如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
如何理解 IP 数据报中的 TTL?
目录 前言理解 前言 面试灵魂一问:说说对 IP 数据报中 TTL 的理解?我们都知道,IP 数据报由首部和数据两部分组成,首部又分为两部分:固定部分和可变部分,共占 20 字节,而即将讨论的 TTL 就位于首…...
Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)
参考官方文档:https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java(供 Kotlin 使用) 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...
PAN/FPN
import torch import torch.nn as nn import torch.nn.functional as F import mathclass LowResQueryHighResKVAttention(nn.Module):"""方案 1: 低分辨率特征 (Query) 查询高分辨率特征 (Key, Value).输出分辨率与低分辨率输入相同。"""def __…...
Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战
说明:这是一个机器学习实战项目(附带数据代码文档),如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下,风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...
【分享】推荐一些办公小工具
1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由:大部分的转换软件需要收费,要么功能不齐全,而开会员又用不了几次浪费钱,借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...
