关于oracle切换mysql8总结

最近由于项目换库,特此记录

1.字段类型

number(8) -> int(8)

number(16) -> bigint(16)

varchar2() -> varchar()

2.导数据

从oracle迁移数据到mysql,除了用专门的数据泵,经常需要用csv导入到mysql;

导出的csv数据如果有中文,需要先用记事本编辑成UTF-8再导入。

关于如何导出正确的csv如下:

1.对于有特殊字符的字段导入后提示不合法或者无法导入时

比如空格处理,有些oracle导出的csv数据含有不可见的换行符char(10)以及回车符chr(13)

比如有 / \ 的,一律使用如下查询消除,将\改为|,剔除回车、空格以及换行

replace(trim(replace(replace(id,chr(13),''),chr(10),'')),'\','|')

如果是clob字段,则先to_char ,然后如上一样的处理

 3.decode

oracle: update table set 字段=decode() where ...

mysql: update table set 字段=case when ... end where ...

4.rownum字段

如果是where条件后面,比如rownum=1改为 limit 1

如果是select后面,比如

select rownum from dual

改为

 SELECT
    ( SELECT @rownum := @rownum + 1 FROM ( SELECT @rownum := 0 ) rownum ) 
FROM
DUAL

5.mysql设置默认时间的字段

select CURRENT_DATE #2024-04-01
select CURRENT_TIME #15:02:54
select CURRENT_TIMESTAMP #2024-04-01 15:03:13 

 6.左右连接

对于a.id=b.id(+) 用left join,a.id(+)=b.id用right join

7.nvl函数

nvl() -> ifnull()

8.merge函数

这个比较有意思,mysql8没有能够实现的函数,代码里多写几个接口吧

9.关于时间的sql改造

记得有一次从oracle导入时间的数据,到了mysql发现时间少了8小时,注意下东八区(GMT+8)问题;

整型: to_number(id)  改为  cast(id as unsigned int)

浮点型:to_number(id)  改为  cast(id as decimal(10,2))

数字转字符串:to_char(id)  改为  convert(id,char)

时间之类的:

to_char(sysdate,'yyyy-mm-dd').  改为 date_format(字段,'%Y-%m-%d')

 (yyyy-mm-dd hh24:mi:ss) -> (%Y-%m-%d %H:%i:%s)

或者(%Y-%m-%d %T)

对于oracle的timestamp类型的数据查询导出时候需要转成年月日时分秒

因为数据长这样:21-4月 -21 02.15.29.556170 下午

这样导入mysql会报错

to_char(wo_date,'yyyy-mm-dd hh24:mi:ss')

然后mysql里字段相应设置为datetime/timestamp即可,注意时区问题,

如果是年月日,mysql对应为date类型

10.关于时间sql运算改造

有趣的是oracle的timestamp类型字段可以直接加减乘除,对,有的业务需要除;

比如字段+1则直接按天加:

字段名+1

mysql里得这样:

date_add(sysdate(),interval 1 day),减写成-1

这个是按天,按月如下

date_add(date_format('2024-01-02','%Y-%m-%d'),interval -8 month)

两个时间相差天数

datediff(time1,time2)

两个日期相差月数

timestampdiff(month,字段,now()) 

11.trunc函数

trunc(1.2233)对应mysql truncate(1.2233,0).  0默认保留整数位

trunc(日期)对应date_format(日期,'%Y-%m-%d')

12.拼接函数

mysql通过concat(字段,字段) 实现拼接 ||

13.start with ... connect by

这个函数着实用了不少时间改造,因为mysql5根本无法实现,必须是mysql8以上的。

这个用于带有组织表数据的分组函数,prior跟随父字段查该条件以上节点,否则查子节点

比如:

select orgId from org z 

start with z.orgid='32401'

connect by prior z.orgid = z.parentorgId;

 改造成mysql需要 使用 with recursive函数

with recursive z1(orgId) as (

     select z0.orgId from org z0 where z0.orgid='32401'

union alll

    select z2.orgid from org z2, z1

where z2.parentorgId = z1.orgId

)

select * from z1;

如果查询父节点, 则绿色部分改为 z2.orgId=z1.parentorgId

14.nulls last/first

order by id nulls last. -> order by if(isnull(id),1,0),id

order by id nulls first -> order by if(isnull(id),0,1),id

15.connect by+level

 oracle比如:

select sysdate+1-rownum sday,level from dual connect by level<=8;

这个忘记是什么业务了,不好直接改,可以先建个表,名叫temp_num,字段只有一个rn(int),然后数据是1-100000,差不多够用就行,这个辅助表会方便很多

后期看到直接套以下语句即可

select rn,date_format(date_add(now(),interval rn-8 day),'%Y-%m-%d %T') sday, 

           8+1-rn

from temp_num tn

where rn<=8;

再来一组:

select trunc(to_date(#{lastDate},'yyyy-mm-dd')) - level +1 DDATE from dual

connect by level<=#{dateSize}

复杂了点,改为

select date_format(date_add(#{lastDate},

interval rn-#{dateSize} day), '%Y-%m-%d') DDATE

from temp_num tn

where rn<=#{dateSize}

 再来一组复杂的

select (to_date('2024-01-01','yyyy-mm-dd') + level -1 ) as every_day

from dual

connect by level<=(trunc(to_date('2024-02-01','yyyy-mm-dd')) -

trunc(to_date('2024-01-01','yyyy-mm-dd')) + 1)

这里的日期是实际上是作为参数传递的,这样写可以直接测试用

改为

SELECT
    rn,date_add( date_format( '2024-01-01', '%Y-%m-%d' ),
    INTERVAL datediff( date_format( '2024-02-01', '%Y-%m-%d' ),
    date_format( '2024-01-01', '%Y-%m-%d' ))+1-rn DAY ) AS every_day 
FROM
    temp_num tn 
WHERE rn <= datediff(date_format( '2024-02-01', '%Y-%m-%d' ),date_format( '2024-01-01', '%Y-%m-%d' )) +1

再比如

SELECT
    add_months ( to_date ( '2024-01-01', 'yyyy-mm-dd' ),- LEVEL + 1 ) dates 
FROM
    DUAL connect BY LEVEL <= 12

改为

SELECT date_add(date_format('2024-01-01','%Y-%m-%d'),interval rn-12 month) as dates
    from temp_num tn
    where rn<=12

上述代码如果复制运行报错,则是空格导致的,删除空格重新写,内容没有问题

16.listagg函数

listagg within group 改为 group_concat

listagg(字段, ';') 改为  group_concat(字段 separator ';')

再比如复杂一点的

listagg(to_char(stat_date,'MM/dd') || '!' || flag, ',') within group(order by stat_date) as data

改为

group_concat(concat(date_format(stat_date,'%m/%d'),'!',flag) order by stat_date SEPARATOR ',') as data

 17.释放表空间

delete from table ,对应myisam会立刻释放表空间,InnoDB不会;

所以在delete之后执行optimize table tableName会释放

如果optimize不支持,

先alter table tableName engine=InnoDB,

再 analyze table tableName

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

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

相关文章

【bugfix】如何解决svg到线上显示空白或者svg的viewBox为空

svgo的默认机制是当width和height和viewbox一样会删除viewbox&#xff0c;这都是为了svg的压缩做的&#xff0c;详情可以看issue中的讨论&#xff0c;我们可以通过更改babel的配置来解决 https://github.com/svg/svgo/issues/1128 https://github.com/ant-design/ant-design-we…

WebSocket用户验证

在WebSocket中&#xff0c;如何携带用户的验证信息 一、在OnMessage中进行验证 客户端在连接到服务器后&#xff0c;客户端通过发送消息&#xff0c;服务器端在OnMessage方法中&#xff0c;进行信息验证&#xff0c;这种方式需要将用户身份验证及接收用户消息进行混合处理&am…

Python人工智能:推动气象科学研究与技术进步的新动力

Python是功能强大、免费、开源&#xff0c;实现面向对象的编程语言&#xff0c;在数据处理、科学计算、数学建模、数据挖掘和数据可视化方面具备优异的性能&#xff0c;这些优势使得Python在气象、海洋、地理、气候、水文和生态等地学领域的科研和工程项目中得到广泛应用。可以…

竞赛常考的知识点大总结(七)图论

最短路 最短路问题&#xff08;Shortest Path Problem&#xff09;是图论中的一个经典问题&#xff0c;它要求在给定的图中找到两个顶点之间的最短路径。最短路问题可以是单源最短路问题&#xff08;从一个顶点到其他所有顶点的最短路径&#xff09;或所有对最短路问题&#x…

Oracle 数据库中的全文搜索

Oracle 数据库中的全文搜索 0. 引言1. 整体流程2. 创建索引2-1. 创建一个简单的表2-2. 创建文本索引2-3. 查看创建的基础表 3. 运行查询3-1. 运行文本查询3-2. CONTAINS 运算符3-3. 混合查询3-4. OR 查询3-5. 通配符3-6. 短语搜索3-7. 模糊搜索&#xff08;Fuzzy searches&…

详细解释Javaweb、Spring和Spring Boot对数据库的使用

在传统的Javaweb中&#xff0c;对数据库进行访问通常使用JDBC&#xff08;Java Database Connectivity&#xff09;来实现。以下是一个简单的示例&#xff0c;演示如何使用JDBC连接数据库并执行查询操作&#xff1a; java import java.sql.Connection; import java.sql.Drive…

2021-08-06

yarn的简介&#xff1a; Yarn是facebook发布的一款取代npm的包管理工具。 yarn的特点&#xff1a; 速度超快。 Yarn 缓存了每个下载过的包&#xff0c;所以再次使用时无需重复下载。 同时利用并行下载以最大化资源利用率&#xff0c;因此安装速度更快。超级安全。 在执行代码…

ChatGPT技巧分享:如何用AI提升学术写作水平

ChatGPT无限次数:点击直达 ChatGPT技巧分享&#xff1a;如何用AI提升学术写作水平 在当今信息爆炸的时代&#xff0c;学术写作是一个重要的技能&#xff0c;但如何提高自己的学术写作水平呢&#xff1f;AI技术的发展为我们提供了更多可能&#xff0c;其中ChatGPT作为一种强大的…

Redis性能瓶颈与安全隐患排查验证纪实

在写《Redis怎样保证数据安全&#xff1f;》这篇文章&#xff0c;我是有对redis设置密码需要哪些步骤&#xff0c;设置密码的性能损耗有验证的。这就涉及到要对redis的配置做修改。 开始时我是打算采用直接使用redis配置文件的方式。所以我从redis官网下载了一个默认的配置文件…

ROS 2边学边练(9)-- 用launch命令管理启动项

概念 我们在前面的ROS 2体验过程中&#xff0c;一直拿小海龟这个例子来练手&#xff0c;过程比较轻松&#xff0c;因为只有两个节点&#xff08;/turtlesim和/teleop_turtle&#xff09;&#xff0c;只需打开两个终端&#xff0c;ros2 run 节点就ok&#xff0c;但&#xff0c;现…

Datacom HCIP笔记-ISIS协议

IS中间系统&#xff08;路由器/运行了ISIS协议的设备&#xff09; ES终端系统(PC,PAD,print) 网络功能模型 ISO定义 事实标准 OSI TCP/IP 网络层(CLNP) (IS-IS) 网络…

EfficientVMamba实战:使用EfficientVMamba实现图像分类任务(一)

文章目录 摘要安装包安装timm 数据增强Cutout和MixupEMA项目结构编译安装Vim环境环境安装过程安装库文件 计算mean和std生成数据集 摘要 论文&#xff1a;https://arxiv.org/pdf/2401.09417v1.pdf 作者研究了轻量级模型设计的新方法&#xff0c;通过引入视觉状态空间模型&…

每天学习一个Linux命令之wget

每天学习一个Linux命令之wget 简介 在Linux系统中&#xff0c;wget是一个使用非常广泛的命令行工具&#xff0c;用于从网络上下载文件。无论是从简单的文件下载&#xff0c;还是通过递归下载整个网站&#xff0c;wget都能帮助你完成。本文将详细介绍wget命令的用法及其可用的…

Git、TortoiseGit、SVN、TortoiseSVN 的关系和区别

Git、TortoiseGit、SVN、TortoiseSVN 的关系和区别 &#xff08;二&#xff09;Git&#xff08;分布式版本控制系统&#xff09;:&#xff08;二&#xff09;SVN&#xff08;集中式版本控制系统&#xff09;&#xff08;三&#xff09;TortoiseGit一、下载安装 git二、安装过程…

python如何处理文本错误

在python中&#xff0c;如果读取的文本文件不在程序的目录中&#xff0c;会提示FileNotFoundError 如果不能确定文本文件是否在目录中&#xff0c;可以用try except语句 代码如下 from pathlib import PathpathPath(alice.txt) try:contentspath.read_text(encodingutf_8) e…

Tomcat调优总结

Tomcat自身的调优是针对conf/server.xml中的几个参数的调优设置。首先是对这几个参数的含义要有深刻而清楚的理解。以tomcat8.5为例&#xff0c;讲解参数。 同时也得认识到一点&#xff0c;tomcat调优也受制于linux内核。linux内核对tcp连接也有几个参数可以调优。 因此可以将…

【C/C++】C语言实现串

C语言实现字符串 简单描述代码运行结果 简单描述 用codeblocks编译通过 源码参考连接 https://gitee.com/IUuaena/data-structures-c.git 代码 guistar_string.h #ifndef GUISTAR_STRING_H_INCLUDED #define GUISTAR_STRING_H_INCLUDED/*! brief 函数返回值枚举 */ typedef e…

scala实现通过Spark统计人均登录次数最终写入MySQL

谨以此博客作为记录 小编这里用的版本是&#xff1a; <hadoop.version>2.7.7</hadoop.version> <spark.version>2.4.5</spark.version> <scala.version>2.12.10</scala.version> 如果没用到Hadoop可以忽略 步骤 准备数据&#xff0c;知道…

C++面向对象程序设计 - 访问对象中成员的3种方法

在C程序中访问对象的成员变量和成员函数&#xff0c;有三种方法&#xff1a; 通过对象名和成员运算符访问对象中的成员&#xff1b;通过指向对象的指针访问对象中的成员&#xff1b;通过对象的引用变量访问对象中的成员 在了解访问对象中成员的3种方法前&#xff0c;先了解下C…

StarRocks部署

介绍 tarRocks 是新一代极速全场景 MPP (Massively Parallel Processing) 数据库。StarRocks 的愿景是能够让用户的数据分析变得更加简单和敏捷。用户无需经过复杂的预处理&#xff0c;就可以用 StarRocks 来支持多种数据分析场景的极速分析。 官网 ## 部署 https://docs.sta…