这应该是一个非常简单的问题,我只是在这里遗漏了一些基本的东西,而且我正在“其中一个日子......”无法使用 Hibernate 或其他 ORM。使用 Java PreparedStatement。
MySQL的东西:
CREATE TABLE `article` (
`articleID` binary(16) NOT NULL,
`publisherID` bigint(20) DEFAULT NULL,
PRIMARY KEY (`articleID`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8$$
insert into article ( articleID, publisherID )
values ( (UNHEX(REPLACE(UUID(),'-',''))), 1111 );
Run Code Online (Sandbox Code Playgroud)
Java的东西
PreparedStatement ps = connection.prepareStatement( "select articleID, publisherID from article" );
ResultSet rs = ps.executeQuery();
while( rs.next())
{
byte[] artIDArr = rs.getBytes( "articleID" );
UUID artID = UUID.nameUUIDFromBytes( artIDArr );
}
rs.close();
ps.close();
Run Code Online (Sandbox Code Playgroud)
现在,从数据库中读取 UUID...
select hex(articleID) from article;
1C711C50E4773873AB1533401E2F420C
A1FCD341EE9311E297B700FFB00BB509
A95E06B6EEE611E297B700FFB00BB509
Run Code Online (Sandbox Code Playgroud)
但是转储我在java代码中读到的内容:
6c825dc9-c98f-37ab-b01b-416294811a84
de6337f9-f276-3e30-b9a3-8d9338a1977f
57ccb5af-1a66-329f-b069-69638e1af24f
Run Code Online (Sandbox Code Playgroud)
现在,这是因为我在将它们存储为二进制文件之前从 UUID 中删除了破折号,并且再水化假设它们在那里?
将 MySql 中存储为 binary(16) 的 UUID 读取到 Jav UUID 对象的正确方法是什么?
编辑:如果我将preparedStatment 查询更改为“select hex(articleID) as articleID...”并将其作为字符串读取,当然这是数据库包含的内容,但UUID 会抛出异常,因为该字符串缺少破折号。 ..
UUID artID = UUID.nameUUIDFromBytes(artIDArr);
Run Code Online (Sandbox Code Playgroud)
使用 MD5 和补丁字节。使用类似的东西
static UUID toUUID(byte[] bytes) {
if (bytes.length != 16) {
throw new IllegalArgumentException();
}
int i = 0;
long msl = 0;
for (; i < 8; i++) {
msl = (msl << 8) | (bytes[i] & 0xFF);
}
long lsl = 0;
for (; i < 16; i++) {
lsl = (lsl << 8) | (bytes[i] & 0xFF);
}
return new UUID(msl, lsl);
}
UUID artID = toUUID(artIDArr);
Run Code Online (Sandbox Code Playgroud)
因此,我简单地通过在查询中使用 hex() 函数调用包装二进制(16)来解决这个问题。不确定让 DB 处理转换或在 Java 中翻转位哪个更有效。不管怎样,完成了。
PreparedStatement ps = connection.prepareStatement( "select hex(articleID) as articleID, publisherID from article" );
ResultSet rs = ps.executeQuery();
while( rs.next())
{
String artIDStr = rs.getString( "articleID" );
UUID artID = getUUIDFromString( artIDStr );
Run Code Online (Sandbox Code Playgroud)
我会将埃根的答案标记为正确,因为他付出了努力并且它可能有效。8)