oracle nvarchar2问题,Oracle数据库中,使用case语句,遇到VARCHAR2与NVARCHAR2问题

在将SQL Server数据库迁移至Oracle数据库时,遇到了将VARCHAR2类型转换为NVARCHAR2类型的问题。原始SQL中的CASE语句在Oracle中需要显式进行数据类型的CAST操作。修改后的CASE语句对每个条件都进行了CAST转换,确保数据类型的兼容性。此问题涉及到数据库迁移、数据类型转换和Oracle数据库的语法规范。
摘要由CSDN通过智能技术生成

5268f80b9b1e01f982625ef6fac83ca1.png

问题:

在有sqlserver数据库迁移至Oracle数据库时,遇到将VARCHAR2付给NVARCHAR2问题

原sql

CASE A .kindCode

WHEN ‘2321034‘ THEN‘02049‘ WHEN ‘2321035‘ THEN‘11067‘ WHEN ‘2321022‘ THEN‘11067‘ WHEN ‘2321039‘ THEN‘02049‘

WHEN ‘2321041‘ THEN‘10064‘ WHEN ‘2321030‘ THEN‘10047‘ WHEN ‘2321031‘ THEN‘10048‘ WHEN ‘2321032‘ THEN‘02049‘

WHEN ‘2321033‘ THEN‘02049‘ WHEN ‘2321001‘ THEN‘11030‘ WHEN ‘2321002‘ THEN‘10039‘ WHEN ‘2321003‘ THEN‘10040‘

WHEN ‘2321004‘ THEN‘10041‘ WHEN ‘2321005‘ THEN‘10042‘ WHEN ‘2321006‘ THEN‘02017‘ WHEN ‘2321007‘ THEN‘02049‘

WHEN ‘2321008‘ THEN‘02049‘ WHEN ‘2321009‘ THEN‘11067‘ WHEN ‘2321010‘ THEN‘11067‘ WHEN ‘2321011‘ THEN‘11067‘

WHEN ‘2321017‘ THEN‘02049‘ WHEN ‘2321018‘ THEN‘02049‘ WHEN ‘2321019‘ THEN ‘02049‘ WHEN ‘2321020‘ THEN‘04029‘

WHEN ‘2321021‘ THEN‘02049‘ WHEN ‘2321025‘ THEN‘02049‘ WHEN ‘2321040‘ THEN ‘02049‘ WHEN ‘2321016‘ THEN‘02049‘

ELSE ‘2312‘ END AS CLASSESCODE,

修改后

CASE A .kindCode

WHEN CAST(‘2321034‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321035‘ as nvarchar2(10)) THEN CAST(‘11067‘as nvarchar2(10))

WHEN CAST(‘2321022‘ as nvarchar2(10)) THEN CAST(‘11067‘as nvarchar2(10)) WHEN CAST(‘2321039‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10))

WHEN CAST(‘2321041‘ as nvarchar2(10)) THEN CAST(‘10064‘as nvarchar2(10)) WHEN CAST(‘2321030‘ as nvarchar2(10)) THEN CAST(‘10047‘as nvarchar2(10))

WHEN CAST(‘2321031‘ as nvarchar2(10)) THEN CAST(‘10048‘as nvarchar2(10)) WHEN CAST(‘2321032‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10))

WHEN CAST(‘2321033‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321001‘ as nvarchar2(10)) THEN CAST(‘11030‘as nvarchar2(10))

WHEN CAST(‘2321002‘ as nvarchar2(10)) THEN CAST(‘10039‘as nvarchar2(10)) WHEN CAST(‘2321003‘ as nvarchar2(10)) THEN CAST(‘10040‘as nvarchar2(10))

WHEN CAST(‘2321004‘ as nvarchar2(10)) THEN CAST(‘10041‘as nvarchar2(10)) WHEN CAST(‘2321005‘ as nvarchar2(10)) THEN CAST(‘10042‘as nvarchar2(10))

WHEN CAST(‘2321006‘ as nvarchar2(10)) THEN CAST(‘02017‘as nvarchar2(10)) WHEN CAST(‘2321007‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10))

WHEN CAST(‘2321008‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321009‘ as nvarchar2(10)) THEN CAST(‘11067‘as nvarchar2(10))

WHEN CAST(‘2321010‘ as nvarchar2(10)) THEN CAST(‘11067‘as nvarchar2(10)) WHEN CAST(‘2321011‘ as nvarchar2(10)) THEN CAST(‘11067‘as nvarchar2(10))

WHEN CAST(‘2321017‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321018‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10))

WHEN CAST(‘2321019‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321020‘ as nvarchar2(10)) THEN CAST(‘04029‘as nvarchar2(10))

WHEN CAST(‘2321021‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321025‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10))

WHEN CAST(‘2321040‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10)) WHEN CAST(‘2321016‘ as nvarchar2(10)) THEN CAST(‘02049‘as nvarchar2(10))

ELSE CAST(‘2312‘ as nvarchar2(10)) END AS CLASSESCODE,

详细问题:https://blog.csdn.net/liuxiyangyang/article/details/8446692

Oracle数据库中,使用case语句,遇到VARCHAR2与NVARCHAR2问题

标签:语句   art   else   数据库   迁移   https   遇到   ast   问题:

1428d0e076c3959ab11d28a39bc84fab.png

5268f80b9b1e01f982625ef6fac83ca1.png

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:https://www.cnblogs.com/zhxb/p/9777249.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值