使用UUID作为主键时,Hibernate会出现错误的ID值

Gon*_*ndy 3 java spring hibernate spring-data

我的实体:

@Entity
@Table(name = "eh_portal")
public class PortalEntity {

    @Id
    @Column(name = "id", columnDefinition = "CHAR(36)")
    private UUID id; //java.util.UUID;

    @Column(name = "name")
    private String name;

    @Column(name = "url")
    private String url;

    // -- Constructor for Hibernate --
    protected PortalEntity() {
    }

    // -- Constructor for new entity in service code --
    public PortalEntity(final UUID id) {
        this.id = id;
    }
    .... getters and setters ommited
}
Run Code Online (Sandbox Code Playgroud)

存储库是Spring DATA JPA:

public interface PortalRepository extends CrudRepository<PortalEntity, UUID> {

}
Run Code Online (Sandbox Code Playgroud)

MYSQL 5数据库表定义:

CREATE TABLE `eh_portal` (
  `id` char(36) NOT NULL COMMENT 'UUID',
  `name` varchar(255) NOT NULL,
  `url` varchar(255) NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `url_UNIQUE` (`url`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
Run Code Online (Sandbox Code Playgroud)

问题是,Hibernate显然返回了错误的数据 - 请参阅Mysql workbench下面的截图:

在此输入图像描述

通过Spring Data JPA获取实体的实际网页: 在此输入图像描述

你可以看到UUID明显不同,而其他列是正确的.这有什么不对?(Spring 4,Hibernate 4,Spring DATA JPA,Mysql 5)

小智 12

尝试使用@Type(type="uuid-char").

  • 您能解释一下为什么这有效和/或有必要吗?谢谢 (2认同)