相关疑难解决方法(0)

如何将uuid存储为数字?

基于问题的答案,MySQL中的UUID性能,答案的人建议将UUID存储为数字而不是字符串.我不太确定如何做到这一点.有人可以建议我吗?我的ruby代码如何处理?

mysql uuid

74
推荐指数
2
解决办法
5万
查看次数

用 Java 读取 MySQL 二进制 (16) UUID

这应该是一个非常简单的问题,我只是在这里遗漏了一些基本的东西,而且我正在“其中一个日子......”无法使用 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 mysql uuid

6
推荐指数
2
解决办法
1万
查看次数

标签 统计

mysql ×2

uuid ×2

java ×1