统一SQL 支持Oracle CHAR和VARCHAR2 (size BYTE|CHAR)转换

统一SQL介绍

https://www.light-pg.com/docs/LTSQL/current/index.html

源和目标

源数据库:Oracle

目标数据库:Postgresql,TDSQL-MySQL,达梦8,LightDB-Oracle

操作目标

在Oracle中的CHAR和VARCHAR2数据类型,如下图所示,根据参数语义,在存储时可以选择以字节还是字符进行存储。

目前统一SQL也加上了BYTE和CHAR两个语法词的解析,根据目标库对该语义的支持程度进行SQL改写。

统一SQL转换

下表是oracle到目标库通过统一SQL转换前后的对比

Oracle2Posgresql

转换前后SQL:

-- 转换前Oracle SQL  char/character
CREATE TABLE unisql_character_type_test(c1 char,c2 char(10),c3 char(10 byte),c4 char(10 char),c11 character,c12 character(10),c13 character(10 byte),c14 character(10 char));
-- 转换后Postgresql SQL char/character
CREATE TABLE unisql_character_type_test (c1 char,c2 char(10),c3 char(10),c4 char(10),c11 char,c12 char(10),c13 char(10),c14 char(10))



-- 转换前Oracle SQL  varchar2/varchar
CREATE TABLE unisql_character_type_test(c1 varchar2(10),c2 varchar2(10 byte),c3 varchar2(10 char),c11 varchar(10),c12 varchar(10 byte),c13 varchar(10 char));
-- 转换后Postgresql SQL varchar2/varchar
CREATE TABLE unisql_character_type_test (c1 varchar(10),c2 varchar(10),c3 varchar(10),c11 varchar(10))

Oracle2TDSQL-MySQL

转换前后SQL:

-- 转换前Oracle SQL  char/character
CREATE TABLE unisql_character_type_test(c1 char,c2 char(10),c3 char(10 byte),c4 char(10 char),c11 character,c12 character(10),c13 character(10 byte),c14 character(10 char));
-- 转换后TDSQL-MySQL SQL char/character
CREATE TABLE `unisql_character_type_test` (`c1` char,`c2` char(10),`c3` char(10),`c4` char(10),`c11` char,`c12` char(10),`c13` char(10),`c14` char(10))



-- 转换前Oracle SQL  varchar2/varchar
CREATE TABLE unisql_character_type_test(c1 varchar2(10),c2 varchar2(10 byte),c3 varchar2(10 char),c11 varchar(10),c12 varchar(10 byte),c13 varchar(10 char));
-- 转换后TDSQL-MySQL SQL varchar2/varchar
CREATE TABLE `unisql_character_type_test` (`c1` varchar(10),`c2` varchar(10),`c3` varchar(10),`c11` varchar(10))

Oracle2DM

转换前后SQL:

-- 转换前Oracle SQL  char/character
CREATE TABLE unisql_character_type_test(c1 char,c2 char(10),c3 char(10 byte),c4 char(10 char),c11 character,c12 character(10),c13 character(10 byte),c14 character(10 char));
-- 转换后达梦8 SQL char/character
CREATE TABLE unisql_character_type_test(c1 char,c2 char(10),c3 char(10 byte),c4 char(10 char),c11 character,c12 character(10),c13 character(10 byte),c14 character(10 char))



-- 转换前Oracle SQL  varchar2/varchar
CREATE TABLE unisql_character_type_test(c1 varchar2(10),c2 varchar2(10 byte),c3 varchar2(10 char),c11 varchar(10),c12 varchar(10 byte),c13 varchar(10 char));
-- 转换后达梦8 SQL varchar2/varchar
CREATE TABLE unisql_character_type_test(c1 varchar2(10),c2 varchar2(10 byte),c3 varchar2(10 char),c11 varchar(10))

Oracle2LightDB-Oracle

转换前后SQL:

-- 转换前Oracle SQL  char/character
CREATE TABLE unisql_character_type_test(c1 char,c2 char(10),c3 char(10 byte),c4 char(10 char),c11 character,c12 character(10),c13 character(10 byte),c14 character(10 char));
-- 转换后LightDB-Oracle SQL char/character
CREATE TABLE unisql_character_type_test(c1 char,c2 char(10),c3 char(10 byte),c4 char(10 char),c11 character,c12 character(10),c13 character(10 byte),c14 character(10 char))



-- 转换前Oracle SQL  varchar2/varchar
CREATE TABLE unisql_character_type_test(c1 varchar2(10),c2 varchar2(10 byte),c3 varchar2(10 char),c11 varchar(10),c12 varchar(10 byte),c13 varchar(10 char));
-- 转换后LightDB-Oracle SQL varchar2/varchar
CREATE TABLE unisql_character_type_test(c1 varchar2(10),c2 varchar2(10 byte),c3 varchar2(10 char),c11 varchar(10))


Oracle其他数据类型到目标库的转换可参考统一SQL官方手册

https://www.light-pg.com/docs/LTSQL/current/index.html

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

6.2 整合MongoDB

6.2 整合MongoDB 1. MongoDB简介2. MongoDB安装2.1 下载2.2 配置MongoDB2.3 MongoDB的启动和关闭1. 启动MongoDB2. 关闭MogoDB 2.4 安全管理 3. 整合SpringBoot3.1 依赖3.2 MongoTemplate使用3.3 测试1. 新增2. 查询3. 删除 *************************************************…

sudo的设置

sudo指令就是提高你的用户权限,用来完成root可以完成的工作,但是有一个前提,就是被root添加到信任名单中,接下来我们要讲解如何在root中添加用户到信任名单中。 在root中输入指令: 即可到达添加信用列表的位置&#x…

读天才与算法:人脑与AI的数学思维笔记08_生物的创造力

1. 生物的创造力 1.1. 在进化树中是否有其他的物种已经具有与我们人类相当的创造力水平 1.2. 20世纪50年代中期,动物学家德斯蒙德莫里斯(Desmond Morris)在伦敦动物园做了这样一个试验 1.2.1. 动物学家给…

基于卷积神经网络的垃圾图像分类系统研究与实现

1.摘要 垃圾分类作为资源回收利用的重要环节之一, 可以有效地提高资源回收利用效率, 进一步减轻环境污染带来的危害. 随着现代工业逐步智能化, 传统的图像分类算法已经不能满足垃圾分拣设备的要求. 本文提出一种基于卷积神经网络的垃圾图像分类模型 (Garbage Classification Ne…

RF高频腔设计(7)

3.11 高阶模 之前我们说过,由于束流负载或者其它的原因会在RF高频腔中激发出很多模式,这些模式可能会对束流的稳定性造成不利的影响,尤其是腔的 R / Q ∗ Q L R/Q*Q_L R/Q∗QL​很高时。 为了解决这个问题,需要使用HOM阻尼器来抑…

数字化化转型中,人的重要性仍然不容忽视!

今日,蚓链多个数字化营销项目进行了复盘,最后数据显示:营销数据表现向上且居于高端的企业不仅仅是营销机制设置的科学、贴合市场,数据好的更主要原因还是体现在“人”!是团队的构成科学合理,拿到好结果的大…

AWVS的使用

AWVS的使用 1、使用docker拉取AWVS的镜像 docker pull secfa/docker-awvs 2.使用AWVS docker run -it -d -p 13443:3443 --cap-add LINUX_IMMUTABLE secfa/docker-awvs 3.访问 4.输入账号密码 https://hub.docker.com/r/secfa/docker-awvs 找到账号密码 username:adminadmin.…

1W 1.5KVDC 3KVDC 隔离宽范围输入,单、双输出 DC/DC 电源模块——TP2L-1W 系列

TP2L-1W系列是一款高性能、超小型的电源模块,宽范围2:1,4:1输入,输出有稳压和连续短路保护功能,隔离电压为1.5KVDC,3KVDC工作温度范围为–40℃到85℃。特别适合对输出电压的精度有严格要求的地方,外部遥控功…

【Python】爬虫-基础入门

目录 一、什么是爬虫 二、爬虫的主要用途 三、学会爬虫需要掌握的技能 四、爬虫使用的语言 五、编写爬虫需要的库,以python为例 六、爬虫示例-python 示例一 示例二 示例三 一、什么是爬虫 爬虫,又称网络爬虫或网页爬虫,是一种用来自…

《智能前沿:应对ChatGPT算力挑战》

在全球人工智能热潮中,以 ChatGPT 为代表的 AIGC 技术引发了广泛关注。人工智能和机器学习等技术对数据规模及处理速度等提出了更高要求。在数据成为主要生产要素的当下和未来,如何跟上时代的发展步伐,构建适应 AI 需求的数据中心&#xff0c…

Keil和VSCode协同开发STM32程序

系列文章 STM32单片机系列专栏 C语言术语和结构总结专栏 文章目录 1. 配置环境 2. 测试打开工程 3. 测试编译工程 随着项目的复杂度上升,开发者不仅需要强大的硬件支持,还需要一个高效和灵活的开发环境。 vscode是一款集成大量可以便携开发插件的代码…

自动化软件测试策略

作为一名软件开发人员,我在不同的公司工作过,具有不同的软件测试流程。在大多数情况下,没有特定/记录的测试方法......因此该过程的内容/方式取决于各个开发人员。与大多数情况一样,当没有强制执行或至少记录在案的政策时&#xf…

齐护K210系列教程(七)_LCD显示数据

LCD显示数据 文章目录 LCD显示数据1,显示英文2,显示传感器的数值3,显示中文4,课程资源 联系我们 LCD的最大分辨率为320*240,所以当我们设置文字或图像坐标时,后面要记住这一点,当然,…

如何将web content项目导入idea并部署到tomcat

将Web Content项目导入IntelliJ IDEA并部署到Tomcat主要涉及以下几个步骤: 1. 导入Web Content项目 打开IntelliJ IDEA。选择“File” -> “New” -> “Project from Existing Sources…”。浏览到你的Web Content项目的文件夹,并选择它。Intell…

QA的成长之路——深入测试的奇妙之旅

引言 功能测试的小伙伴,你们是否遇到过这些问题: 1、工作中重复性很高:尽管尽可能地让一个 case 覆盖更多场景,但仍有许多重复性 case,耗费大量时间,让人感到枯燥疲惫; 2、覆盖度不全&#x…

Bitmap 原理简述

之前写过一篇 bitmap 应用场景的文章https://blog.csdn.net/maray/article/details/136923316 本文介绍 bitmap 的原理: 下面有三张表:user_info_base, user_prefer, user_device,我们希望查询“喜欢电子产品并且使用iPhone的女性用户”&…

食用油5G智能工厂数字孪生可视化平台,推进食品制造业数字化转型

食用油5G智能工厂数字孪生可视化平台,推进食品制造业数字化转型。在食用油产业中,数字化转型已成为提升生产效率、优化供应链管理、确保产品质量和满足消费者需求的关键。食用油5G智能工厂数字孪生可视化平台作为这一转型的重要工具,正在推动…

数据结构之顺序表(java版)

目录 一.线性表 1.1线性表的概念 二.顺序表 2.1顺序表的概念 2.2顺序表的实现 1.顺序表的接口 1.2顺序表的功能实现 1.顺序表初始化 2.新增元素功能: 3.清空顺序表是否为空&&获取顺序表长度&&打印顺序表: 4.判断是否包含某个…

关于开设YOLOv8专栏及更新内容的一些说明

​ 专栏介绍:YOLOv9改进系列 | 包含深度学习最新创新,助力高效涨点!!! 专栏介绍 ⭐后期更新包含模块、卷积、检测头、损失等改进,目前已有70!现在入手仅$ 69.9,早入早发论文!⭐ ⭐…

【前端技术】HTML基础入门篇

1.1 HTML简介 ​ HTML(HyperText Markup Language:超文本标记语言)是一种标识性的语言。它包括一系列标签.通过这些标签可以将网络上的文档格式统一,使分散的Internet资源连接为一个逻辑整体。HTML文本是由HTML命令组…