强制转换中的数据类型不一致

Posted

技术标签:

【中文标题】强制转换中的数据类型不一致【英文标题】:Inconsistent datatype in cast 【发布时间】:2021-10-11 11:30:39 【问题描述】:

我有以下 SQL 查询,我必须将其转换为 Oracle 查询:

select binaryPhotoNumber, cast(cast(PhotoInfo as varbinary(max)) as varchar(max)) as PhotoInfo
From ProfilePictures
Where profilesourceid = 10

我尝试将其转换为 Oracle,结果如下

select binaryPhotoNumber, cast(cast(PhotoInfo as BLOB) as CLOB) as PhotoInfo
From ProfilePictures
Where profilesourceid = 10

但是,我遇到了一个错误

不一致的数据类型:预期 - 得到 BLOB。

DDL:

binaryPhotoNumber is Number

PhotoInfo is BLOB

profilesourceid is Number 

现在我知道 PhotoInfo 是 BLOB 所以,我将查询更改为以下内容

select binaryPhotoNumber, cast(PhotoInfo as CLOB) as PhotoInfo
    From ProfilePictures
    Where profilesourceid = 10

现在它给了我

不一致的数据类型:预期 - 得到 CLOB。

【问题讨论】:

请添加表的ddl?并且 cast 不支持将 LOB 作为目标,这是 21c 手册所说的: CAST 不直接支持任何 LOB 数据类型。当您使用 CAST 将 CLOB 值转换为字符数据类型或将 BLOB 值转换为 RAW 数据类型时,数据库会隐式地将 LOB 值转换为字符或原始数据,然后将结果值显式转换为目标数据类型。 ... @gsalem 我更新了我的问题并添加了详细信息 我认为to_clob(PhotoInfo) 可能是您最好的选择,但请参阅this similar question @kfinity 现在它说,预期 char 得到 blob 直接来自文档:CAST 不直接支持任何 LOB 数据类型。您可以尝试to_clob(to_blob(whatever))(假设它有意义; 对我来说不是 - 将结果保留为 BLOB 有什么问题?为什么需要将其转换为 CLOB?) 【参考方案1】:

由于它是 XML 数据,您可以使用以下方法将其转换为 XMLType:

xmltype(photoinfo, 0)

要使用数据库字符集,或指定字符集(可能是 UTF-8,但可能不是),您可以通过以下方式指定:

xmltype(photoinfo, nls_charset_id('UTF8'))

一旦您将它作为该数据类型,您就可以将其作为 XML 进行操作,具有 XMLQuery 和 XMLTable 之类的功能 (read more);或者只是将整个事情视为 CLOB,您可以这样做:

xmltype(photoinfo, nls_charset_id('UTF8')).getclobval()

【讨论】:

以上是关于强制转换中的数据类型不一致的主要内容,如果未能解决你的问题,请参考以下文章

Java中的强制类型转换是如何转换的?

Java中的强制类型转换是如何转换的?

在C#中如何将int类型强制转换为double类型

c语言强制转换的疑问

强制类型转换

C++中的数据类型强制转换