6

これは非常に単純な質問です。ここで基本的なものが欠けているだけで、「ある日...」が発生しています。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をJava UUIDオブジェクトに読み取る正しい方法は何ですか?

編集:preparedStatmentクエリを「select hex(articleID) as articleID...」に変更して文字列として読み取ると、もちろんDBに含まれるものですが、文字列にダッシュがないため、UUIDは例外をスローします。 ..

4

2 に答える 2

5
UUID artID = UUID.nameUUIDFromBytes(artIDArr);

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);
于 2013-07-18T15:12:04.407 に答える