Oracle问题记录

勤奋不是嘴上说说而已,而是实际的行动,在勤奋的苦度中持之以恒,永不退却。业精于勤,荒于嬉;行成于思,毁于随。在人生的仕途上,我们毫不迟疑地选择勤奋,她是几乎于世界上一切成就的催产婆。只要我们拥着勤奋去思考,拥着勤奋的手去耕耘,用抱勤奋的心去对待工作,浪迹红尘而坚韧不拔,那么,我们的生命就会绽放火花,让人生的时光更加的闪亮而精彩。

导读:本篇文章讲解 Oracle问题记录,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

概述

只稍微熟悉MySQL,但是不可避免会使用Oracle,此文记录Oracle使用问题。

问题

获取版本号

SELECT version FROM PRODUCT_COMPONENT_VERSION WHERE product LIKE 'Oracle Database%';
输出:19.0.0.0.0

字段最大长度

和通用SQL类似:select max(length(C_LONG_COMMENTS))from SYSADM.C_BATCH_TBL;

ORA-00942:表或视图不存在

在这里插入图片描述
很简单的Select查询语句,报错如上。数据库owner坚称表或视图存在。

原因:连接该数据库的用户没有查看该表或视图的权限,故而报错。需要联系数据库owner,或管理员添加权限。

另,在获得权限后,DataGrip依旧是红色警告,点击SYSADM,确实看不到表或视图,但是不影响SQL查询获取结果。

ORA-00911:无效字符

在这里插入图片描述
复制到DataGrip里面,\r\n没有变成回车换行,居然报错。SQL在JDBC程序里面执行是没有问题的。

ORA-00933:SQL command not properly ended

一段简单的SQL查询语句放在DataGrip执行成功,但是在JDBC代码里面执行失败:

select C_BATCH_ID from SYSADM.C_BATCH_TBL;

在这里插入图片描述
断点调试,发现原因居然是多了一个;!!!!
在这里插入图片描述

数据同步

Oracle到MySQL的数据同步。

大小写

在这里插入图片描述
Oracle自动将查询的结果变成大写,同步到MySQL,表字段定义允许是下划线命名的。

时间戳BatchUpdateException: Data truncation: Incorrect datetime value

Oracle的时间戳数据支持毫秒数
在这里插入图片描述
同步到MySQL时,不管MySQL字段定义为timestamp还是varchar,同步数据都会报错:

java.lang.Exception: java.lang.Exception: java.sql.BatchUpdateException: Data truncation: Incorrect datetime value: '\\xAC\\xED\\x00\\x05sr\\x00\\x14oracle.sql.TIMESTAMP\\x91w\\x95\\xC2\\x99Ud\\x1F\\x02\\x00\\x00xr\\x00\\x10oracle.sql.Datum@x\\xF5\\x14\\xA3b(o\\x02' for column 'CREATEDTTM' at row 1
java.lang.Exception: java.lang.Exception: java.sql.BatchUpdateException: Incorrect string value: '\\xAC\\xED\\x00\\x05sr...' for column 'CREATEDTTM' at row 1

解决方法:
TO_CHAR(CREATEDTTM, 'YYYY-MM-DD HH24:MI:SS') as CREATEDTTM

clob类型序列化问题NotSerializableException: oracle.jdbc.driver.T4CConnection

在这里插入图片描述
Oracle字段定义为CLOB,MySQL定义为varchar或text,都会报错:

2021-12-21 11:47:33,257 [http-nio-8082-exec-3] INFO  c.x.c.a.b.s.DataProviderService- execAutoWork
java.lang.Exception: java.lang.Exception: java.sql.SQLException: Invalid argument value: java.io.NotSerializableException
Caused by: java.lang.Exception: java.sql.SQLException: Invalid argument value: java.io.NotSerializableException
Caused by: java.sql.SQLException: Invalid argument value: java.io.NotSerializableException
Caused by: com.mysql.cj.exceptions.WrongArgumentException: Invalid argument value: java.io.NotSerializableException
Caused by: java.io.NotSerializableException: oracle.jdbc.driver.T4CConnection

解决方法:
CAST(C_LONG_COMMENTS AS VARCHAR2(3000)) as C_LONG_COMMENTS

参考

Oracle to MySQL timestamp conversion in MySQL insert statement
NotSerializableException while getting CLOB data from ORACLE using JDBC

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/142158.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!