【发布时间】:2013-07-18 14:44:42
【问题描述】:
这应该是一个非常简单的问题,我只是在这里遗漏了一些基本的东西,而我正在经历“那些日子……” 不能使用 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 );
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 读取到 Jav UUID 对象的正确方法是什么?
编辑:如果我将preparedStatment查询更改为“选择hex(articleID)作为articleID ...”并将其作为字符串读取,它当然是数据库包含的内容,但UUID会抛出异常,因为缺少字符串破折号...
【问题讨论】:
-
您确定将这些存储为二进制文件值得吗?节省的长度通常很少,而且手动查询非常烦人。
-
是的,我们将有一个巴西的记录,我们需要它是一个更小的 PK。是的,UUID 并不是最好的 PK。我知道。但这就是我所拥有的。谢谢。