这应该是一个非常简单的问题,我只是在某些基础方面遗漏了一些东西,而且今天可能不顺利...不能使用Hibernate或其他ORM。使用Java PreparedStatement。
MySQL相关内容:
现在,从数据库中读取UUID...
但是,根据我在Java代码中阅读到的内容:
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 );
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();
现在,从数据库中读取UUID...
select hex(articleID) from article;
1C711C50E4773873AB1533401E2F420C
A1FCD341EE9311E297B700FFB00BB509
A95E06B6EEE611E297B700FFB00BB509
但是,根据我在Java代码中阅读到的内容:
6c825dc9-c98f-37ab-b01b-416294811a84
de6337f9-f276-3e30-b9a3-8d9338a1977f
57ccb5af-1a66-329f-b069-69638e1af24f
现在的问题是,我在将UUID存储为二进制之前是否要删除其中的破折号,而重新生成时是否会假定它们存在?
在MySQL中将以二进制(16)形式存储的UUID正确地读取为Java UUID对象的方法是什么?
编辑:如果我将preparedStatment查询更改为"select hex(articleID) as articleID..."并将其作为字符串读取,则它显然是DB包含的内容,但UUID会抛出异常,因为该字符串缺少破折号...