ORACLE RAW,字符串格式为标准GUID

时间:2016-06-07 16:33:24

标签: java oracle

我正在尝试寻找将Oracle RAW GUID格式的String格式转换为标准GUID格式的解决方案。我无法找到我的用例的解决方案。这是我正在寻找的一个例子:

ORACLE RAW (String): 9BB2A2B8DF8747B0982F2F1702E1D18B 

这需要使用Java代码转换为标准或括号内的GUID

B8A2B29B-87DF-B047-982F-2F1702E1D18B or {B8A2B29B-87DF-B047-982F-2F1702E1D18B} 

提前感谢您的帮助。

2 个答案:

答案 0 :(得分:5)

一种简单的方法是在选择时将RAW GUID转换为VARCHAR。然后从结果集中将其作为String读取。这是公式:

select 
 upper(
    regexp_replace(
        regexp_replace(
            hextoraw('9BB2A2B8DF8747B0982F2F1702E1D18B'),
            '(.{8})(.{4})(.{4})(.{4})(.{12})',
            '\1-\2-\3-\4-\5'
        ),
        '(.{2})(.{2})(.{2})(.{2}).(.{2})(.{2}).(.{2})(.{2})(.{18})',
        '\4\3\2\1-\6\5-\8\7\9'
    )
 ) from dual

这是我找到查询的参考(我必须调整它,因为原文有一些错误):https://community.oracle.com/thread/1063096?tstart=0

或者如果您想使用Java,那么在Java中翻译上述解决方案非常简单:

/**
 * input: "9BB2A2B8DF8747B0982F2F1702E1D18B"
 * output: "B8A2B29B-87DF-B047-982F-2F1702E1D18B";
 */
public String hexToStr(String guid) {       
    return guid.replaceAll("(.{8})(.{4})(.{4})(.{4})(.{12})", "$1-$2-$3-$4-$5").replaceAll("(.{2})(.{2})(.{2})(.{2}).(.{2})(.{2}).(.{2})(.{2})(.{18})", "$4$3$2$1-$6$5-$8$7$9");
}

使用类java.util.UUID的更标准方法是不可能的,因为SYS_GUID()的Oracle实现不符合RFC 4122.请参阅Is Oracle's SYS_GUID() UUID RFC 4122 compliant?

答案 1 :(得分:0)

我编写了一个控制台应用程序来执行此转换。这很有用,因为我每天需要多次这样做。

必须编译并定义路径上的输出目录。

https://github.com/lucassc/oracleuuid

Exemple