HaloDB 的 Oracle 兼容模式

news2025/1/4 14:01:15

↑ 关注“少安事务所”公众号,欢迎⭐收藏,不错过精彩内容~

前倾回顾

前面介绍了“光环”数据库的基本情况和安装办法。

  • 哈喽,国产数据库!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 / --

alt

如果这篇文章为你带来了灵感或启发,就请帮忙点『赞』or『在看』or『转发』吧,感谢!(๑˃̵ᴗ˂̵)

本文由 mdnice 多平台发布

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1715095.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python Selenium 详解:实现高效的UI自动化测试

落日余辉,深情不及久伴。大家好,在当今软件开发的世界中,自动化测试已经成为保障软件质量和快速迭代的重要环节。而在自动化测试的领域中,UI自动化测试是不可或缺的一部分,它可以帮助测试团队快速验证用户界面的正确性…

爬虫案例(读书网)

一.我们还是使用简单的bs4库和lxml,使用xpath: 导入下面的库: import requests from bs4 import BeautifulSoup from lxml import etree 我们可以看见它的div和每个书的div框架,这样会观察会快速提高我们的简单爬取能力。 二.实…

Nginx网页服务

nginx的配置: 1、全局块:全局配置,对全局生效; 2、events块:配置影响 Nginx 服务器与用户的网络连接; 3、http块:配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置&#xf…

C语言---文件操作

【C语言详解】——文件操作&#xff08;建议收藏&#xff09;_c语言 写文件原理-CSDN博客 一、文件的读取 # define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<errno.h> #include<string.h>int main() {FILE * pffopen("C:\\Users\\zhw\\De…

Java中的ORM框架——myBatis

一、什么是ORM ORM 的全称是 Object Relational Mapping。Object代表应用程序中的对象&#xff0c;Relational表示的是关系型数据库&#xff0c;Mapping即是映射。结合起来就是在程序中的对象和关系型数据库之间建立映射关系&#xff0c;这样就可以用面向对象的方式&#xff0c…

Vue3使用Composition API实现响应式

title: Vue3使用Composition API实现响应式 date: 2024/5/29 下午8:10:24 updated: 2024/5/29 下午8:10:24 categories: 前端开发 tags: Vue3CompositionRefsReactiveWatchLifecycleDebugging 1. 介绍 Composition API是Vue.js 3中新增的一组API&#xff0c;用于在组件中组…

服装服饰商城小程序的作用是什么

要说服装商家&#xff0c;那数量是非常多&#xff0c;厂家/经销门店/小摊/无货源等&#xff0c;线上线下同行竞争激烈&#xff0c;虽然用户群体广涵盖每个人&#xff0c;但每个商家肯定都希望更多客户被自己转化&#xff0c;渠道运营方案营销环境等不可少。 以年轻人为主的消费…

30【Aseprite 作图】桌子——拆解

1 桌子只要画左上方&#xff0c;竖着5&#xff0c;斜着3个1&#xff0c;斜着两个2&#xff0c;斜着2个3&#xff0c;斜着一个5&#xff0c;斜着一个很长的 然后左右翻转 再上下翻转 在桌子腿部分&#xff0c;竖着三个直线&#xff0c;左右都是斜线&#xff1b;这是横着水平线不…

使用NuScenes数据集生成ROS Bag文件:深度学习与机器人操作的桥梁

在自动驾驶、机器人导航及环境感知的研究中&#xff0c;高质量的数据集是推动算法发展的关键。NuScenes数据集作为一项开源的多模态自动驾驶数据集&#xff0c;提供了丰富的雷达、激光雷达&#xff08;LiDAR&#xff09;、摄像头等多种传感器数据&#xff0c;是进行多传感器融合…

检索字符串

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在Python中&#xff0c;字符串对象提供了很多应用于字符串查找的方法&#xff0c;这里主要介绍以下几种方法。 &#xff08;1&#xff09;count()方…

Visual Studio 的调试

目录 引言 一、调试的基本功能 设置断点 启动调试 检查变量 逐步执行代码 调用堆栈 使用即时窗口 二、调试技巧 条件断点 日志断点 数据断点 异常调试 三、调试高级功能 远程调试 多线程调试 内存调试 性能调试 诊断工具 四、调试策略与最佳实践 系统化的…

Docker-一文详解容器通信的基础网络模式及衍生的自定义网络模式

启动容器时&#xff0c;通过-p 宿主机端口:容器端口&#xff0c;就可以通过访问宿主机端口访问到容器&#xff0c;这种原理机制是啥&#xff0c;有没有其它方式可以让宿主机和容器通信&#xff0c;以及容器与容器之间如何通信。带着这几个问题开始学习Docker的网络知识。 文章…

浅谈路由器转发数据包

当路由器转发数据包时&#xff0c;它会经历一系列步骤&#xff0c;包括接收数据包、路由表查询、以及转发数据包。以下是详细的步骤描述&#xff1a; 1. 接收数据包 以太网帧到达端口&#xff1a;当一个以太网帧到达路由器的某个网络接口&#xff08;端口&#xff09;时&#…

STL库--stack

目录 stack的定义 stack容器内元素的访问 stack常用函数实例解析 stack的常见用途 stack的定义 其定义的写法和其他STL容器相同&#xff0c;typename可以任意基本类型或容器&#xff1a; stack<typename> name; stack容器内元素的访问 由于栈本身就是一种后进先出…

成都欣丰洪泰文化传媒有限公司助力品牌快速崛起

在当今数字化浪潮汹涌的时代&#xff0c;电商行业作为新经济的代表&#xff0c;正以其独特的魅力和无限的潜力&#xff0c;引领着商业模式的创新与变革。在这个充满机遇与挑战的领域里&#xff0c;成都欣丰洪泰文化传媒有限公司凭借其专业的电商服务能力和前瞻性的战略眼光&…

【Python】解决Python报错:TypeError: ‘int‘ object is not iterable

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

[测试开发]如何让IDEA实时显示内存

&#x1f525; 交流讨论&#xff1a;欢迎加入我们一起学习&#xff01; &#x1f525; 资源分享&#xff1a;耗时200小时精选的「软件测试」资料包 &#x1f525; 教程推荐&#xff1a;火遍全网的《软件测试》教程 &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1…

GoFly框架快速新增接口/上手写代码

拿到一个新框架大家可能无从下手&#xff0c;因为你对框架设计思路、结构不了解&#xff0c;从而产生恐惧&#xff0c;所以我们框架是通过简单可视化界面安装&#xff0c;安装后即可看到效果&#xff0c;然后点击先点点看各个功能&#xff0c;看现有的功能是怎么写的&#xff0…

[双指针] --- 快乐数 盛最多水的容器

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏&#xff1a; 算法Journey 本篇博客我们分享一下双指针算法中的快慢指针以及对撞双指针&#xff0c;下面我们开始今天的学习吧~ &#x1f3e0; 快乐数 &#x1f4d2; 题…

如何让你的网站能通过域名访问

背景 当我们租一台云服务器&#xff0c;并在上面运行了一个Web服务&#xff0c;我们可以使用云服务器的公网IP地址进行访问&#xff0c;如下&#xff1a; 本文主要记录如何 实现让自己的网站可以通过域名访问。 买域名 可以登录腾讯云等主流公有云平台的&#xff0c;购买域名…