Java example for Hibernate Types
This commit is contained in:
parent
646bd45c18
commit
925a69b401
|
@ -0,0 +1,33 @@
|
||||||
|
.classpath
|
||||||
|
.project
|
||||||
|
HELP.md
|
||||||
|
target/
|
||||||
|
!.mvn/wrapper/maven-wrapper.jar
|
||||||
|
!**/src/main/**
|
||||||
|
!**/src/test/**
|
||||||
|
|
||||||
|
### STS ###
|
||||||
|
.apt_generated
|
||||||
|
.classpath
|
||||||
|
.factorypath
|
||||||
|
.project
|
||||||
|
.settings
|
||||||
|
.springBeans
|
||||||
|
.sts4-cache
|
||||||
|
|
||||||
|
### IntelliJ IDEA ###
|
||||||
|
.idea
|
||||||
|
*.iws
|
||||||
|
*.iml
|
||||||
|
*.ipr
|
||||||
|
|
||||||
|
### NetBeans ###
|
||||||
|
/nbproject/private/
|
||||||
|
/nbbuild/
|
||||||
|
/dist/
|
||||||
|
/nbdist/
|
||||||
|
/.nb-gradle/
|
||||||
|
build/
|
||||||
|
|
||||||
|
### VS Code ###
|
||||||
|
.vscode/
|
|
@ -0,0 +1,7 @@
|
||||||
|
## Hibernate Types
|
||||||
|
|
||||||
|
This module contains articles specific to use of Hibernate Types.
|
||||||
|
|
||||||
|
### Relevant articles:
|
||||||
|
|
||||||
|
- [A Guide to Hibernate Types Project](https://www.baeldung.com/a-guide-to-hibernate-types-project/)
|
|
@ -0,0 +1,19 @@
|
||||||
|
version: '3.2'
|
||||||
|
|
||||||
|
services:
|
||||||
|
mysql:
|
||||||
|
image: mysql:5.7
|
||||||
|
container_name: mysql57
|
||||||
|
restart: unless-stopped
|
||||||
|
ports:
|
||||||
|
- 53306:3306
|
||||||
|
environment:
|
||||||
|
- MYSQL_ALLOW_EMPTY_PASSWORD=true
|
||||||
|
volumes :
|
||||||
|
- ./docker/etc/mysql/conf.d:/etc/mysql/conf.d
|
||||||
|
- ./docker/docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d
|
||||||
|
logging:
|
||||||
|
driver: "json-file"
|
||||||
|
options:
|
||||||
|
max-size: "50m"
|
||||||
|
max-file: "1"
|
|
@ -0,0 +1,3 @@
|
||||||
|
CREATE DATABASE hibernate_types;
|
||||||
|
use hibernate_types;
|
||||||
|
GRANT ALL PRIVILEGES ON hibernate_types.* TO 'mysql'@'%' IDENTIFIED BY 'admin';
|
|
@ -0,0 +1,7 @@
|
||||||
|
[mysqld]
|
||||||
|
init_connect='SET collation_connection = utf8_unicode_ci'
|
||||||
|
character-set-server = utf8
|
||||||
|
collation-server = utf8_unicode_ci
|
||||||
|
|
||||||
|
[client]
|
||||||
|
default-character-set = utf8
|
|
@ -0,0 +1,214 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<artifactId>hibernate-types</artifactId>
|
||||||
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
|
<name>hibernate-types</name>
|
||||||
|
<description>Introduction into hibernate types library</description>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<groupId>com.baeldung</groupId>
|
||||||
|
<artifactId>persistence-modules</artifactId>
|
||||||
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.vladmihalcea</groupId>
|
||||||
|
<artifactId>hibernate-types-52</artifactId>
|
||||||
|
<version>${hibernate-types.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-data-jpa</artifactId>
|
||||||
|
<version>${spring-boot.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
|
<version>${spring-boot.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
<exclusions>
|
||||||
|
<exclusion>
|
||||||
|
<groupId>org.junit.vintage</groupId>
|
||||||
|
<artifactId>junit-vintage-engine</artifactId>
|
||||||
|
</exclusion>
|
||||||
|
</exclusions>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-devtools</artifactId>
|
||||||
|
<version>${spring-boot.version}</version>
|
||||||
|
<scope>runtime</scope>
|
||||||
|
<optional>true</optional>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate</groupId>
|
||||||
|
<artifactId>hibernate-core</artifactId>
|
||||||
|
<version>${hibernate.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate</groupId>
|
||||||
|
<artifactId>hibernate-ehcache</artifactId>
|
||||||
|
<version>${hibernate.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate</groupId>
|
||||||
|
<artifactId>hibernate-testing</artifactId>
|
||||||
|
<version>${hibernate.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.assertj</groupId>
|
||||||
|
<artifactId>assertj-core</artifactId>
|
||||||
|
<version>${assertj-core.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>mysql</groupId>
|
||||||
|
<artifactId>mysql-connector-java</artifactId>
|
||||||
|
<version>${mysql.version}</version>
|
||||||
|
<scope>runtime</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.slf4j</groupId>
|
||||||
|
<artifactId>slf4j-api</artifactId>
|
||||||
|
<version>${slf4j.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
<optional>true</optional>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>ch.qos.logback</groupId>
|
||||||
|
<artifactId>logback-classic</artifactId>
|
||||||
|
<version>${logback.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
<optional>true</optional>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>javax.xml.bind</groupId>
|
||||||
|
<artifactId>jaxb-api</artifactId>
|
||||||
|
<version>${jaxb.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.javassist</groupId>
|
||||||
|
<artifactId>javassist</artifactId>
|
||||||
|
<version>${javassist.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.fasterxml.jackson.core</groupId>
|
||||||
|
<artifactId>jackson-databind</artifactId>
|
||||||
|
<version>${jackson.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
<optional>true</optional>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.google.guava</groupId>
|
||||||
|
<artifactId>guava</artifactId>
|
||||||
|
<version>${guava.version}</version>
|
||||||
|
<scope>provided</scope>
|
||||||
|
<optional>true</optional>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>net.ttddyy</groupId>
|
||||||
|
<artifactId>datasource-proxy</artifactId>
|
||||||
|
<version>${datasource-proxy.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.integralblue</groupId>
|
||||||
|
<artifactId>log4jdbc-spring-boot-starter</artifactId>
|
||||||
|
<version>${log4jdbc.version}</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<finalName>hibernate-types</finalName>
|
||||||
|
<resources>
|
||||||
|
<resource>
|
||||||
|
<directory>src/main/resources</directory>
|
||||||
|
<filtering>true</filtering>
|
||||||
|
</resource>
|
||||||
|
</resources>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-war-plugin</artifactId>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>${maven.version}</version>
|
||||||
|
<configuration>
|
||||||
|
<source>${source.version}</source>
|
||||||
|
<target>${target.version}</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<configuration>
|
||||||
|
<forkCount>3</forkCount>
|
||||||
|
<reuseForks>true</reuseForks>
|
||||||
|
<excludes>
|
||||||
|
<exclude>**/*IntegrationTest.java</exclude>
|
||||||
|
</excludes>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
|
||||||
|
<profiles>
|
||||||
|
<profile>
|
||||||
|
<id>integration</id>
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<phase>integration-test</phase>
|
||||||
|
<goals>
|
||||||
|
<goal>test</goal>
|
||||||
|
</goals>
|
||||||
|
<configuration>
|
||||||
|
<excludes>
|
||||||
|
<exclude>none</exclude>
|
||||||
|
</excludes>
|
||||||
|
<includes>
|
||||||
|
<include>**/*IntegrationTest.java</include>
|
||||||
|
</includes>
|
||||||
|
</configuration>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
</profile>
|
||||||
|
</profiles>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<assertj-core.version>3.15.0</assertj-core.version>
|
||||||
|
<datasource-proxy.version>1.6</datasource-proxy.version>
|
||||||
|
<guava.version>29.0-jre</guava.version>
|
||||||
|
<hibernate-types.version>2.9.7</hibernate-types.version>
|
||||||
|
<hibernate.version>5.4.14.Final</hibernate.version>
|
||||||
|
<jackson.version>2.10.3</jackson.version>
|
||||||
|
<java.version>1.8</java.version>
|
||||||
|
<javassist.version>3.27.0-GA</javassist.version>
|
||||||
|
<jaxb.version>2.3.1</jaxb.version>
|
||||||
|
<log4jdbc.version>2.0.0</log4jdbc.version>
|
||||||
|
<logback.version>1.2.3</logback.version>
|
||||||
|
<maven-jar-plugin.version>3.0.2</maven-jar-plugin.version>
|
||||||
|
<maven.surefire.version>2.22.2</maven.surefire.version>
|
||||||
|
<maven.compiler.version>3.8.1</maven.compiler.version>
|
||||||
|
<maven.version>3.7.0</maven.version>
|
||||||
|
<mysql.version>8.0.19</mysql.version>
|
||||||
|
<slf4j.version>1.7.30</slf4j.version>
|
||||||
|
<spring-boot.version>2.1.3.RELEASE</spring-boot.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
</project>
|
|
@ -0,0 +1,34 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import org.hibernate.annotations.Type;
|
||||||
|
|
||||||
|
import javax.persistence.*;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Entity(name = "Album")
|
||||||
|
@Table(name = "album")
|
||||||
|
public class Album extends BaseEntity {
|
||||||
|
@Type(type = "json")
|
||||||
|
@Column(columnDefinition = "json")
|
||||||
|
private CoverArt coverArt;
|
||||||
|
|
||||||
|
@OneToMany(fetch = FetchType.EAGER)
|
||||||
|
private List<Song> songs;
|
||||||
|
|
||||||
|
public CoverArt getCoverArt() {
|
||||||
|
return coverArt;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCoverArt(CoverArt coverArt) {
|
||||||
|
this.coverArt = coverArt;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public List<Song> getSongs() {
|
||||||
|
return songs;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSong(List<Song> songs) {
|
||||||
|
this.songs = songs;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import org.springframework.data.repository.CrudRepository;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface AlbumRepository extends CrudRepository<Album, Long> {
|
||||||
|
}
|
|
@ -0,0 +1,72 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
public class Artist implements Serializable {
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
private String country;
|
||||||
|
private String genre;
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getCountry() {
|
||||||
|
return country;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCountry(String country) {
|
||||||
|
this.country = country;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getGenre() {
|
||||||
|
return genre;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setGenre(String genre) {
|
||||||
|
this.genre = genre;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
final int prime = 31;
|
||||||
|
int result = 1;
|
||||||
|
result = prime * result + ((country == null) ? 0 : country.hashCode());
|
||||||
|
result = prime * result + ((genre == null) ? 0 : genre.hashCode());
|
||||||
|
result = prime * result + ((name == null) ? 0 : name.hashCode());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
Artist other = (Artist) obj;
|
||||||
|
if (country == null) {
|
||||||
|
if (other.country != null)
|
||||||
|
return false;
|
||||||
|
} else if (!country.equals(other.country))
|
||||||
|
return false;
|
||||||
|
if (genre == null) {
|
||||||
|
if (other.genre != null)
|
||||||
|
return false;
|
||||||
|
} else if (!genre.equals(other.genre))
|
||||||
|
return false;
|
||||||
|
if (name == null) {
|
||||||
|
if (other.name != null)
|
||||||
|
return false;
|
||||||
|
} else if (!name.equals(other.name))
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import com.vladmihalcea.hibernate.type.json.JsonBinaryType;
|
||||||
|
import com.vladmihalcea.hibernate.type.json.JsonStringType;
|
||||||
|
import org.hibernate.annotations.TypeDef;
|
||||||
|
import org.hibernate.annotations.TypeDefs;
|
||||||
|
|
||||||
|
import javax.persistence.*;
|
||||||
|
|
||||||
|
@TypeDefs({
|
||||||
|
@TypeDef(name = "json", typeClass = JsonStringType.class),
|
||||||
|
@TypeDef(name = "jsonb", typeClass = JsonBinaryType.class)
|
||||||
|
})
|
||||||
|
@MappedSuperclass
|
||||||
|
public class BaseEntity {
|
||||||
|
@Id
|
||||||
|
@GeneratedValue(strategy=GenerationType.AUTO)
|
||||||
|
@Column(name = "id", unique = true, nullable = false)
|
||||||
|
long id;
|
||||||
|
String name;
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Long id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,71 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
public class CoverArt implements Serializable {
|
||||||
|
|
||||||
|
private String frontCoverArtUrl;
|
||||||
|
private String backCoverArtUrl;
|
||||||
|
private String upcCode;
|
||||||
|
|
||||||
|
public String getFrontCoverArtUrl() {
|
||||||
|
return frontCoverArtUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFrontCoverArtUrl(String frontCoverArtUrl) {
|
||||||
|
this.frontCoverArtUrl = frontCoverArtUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getBackCoverArtUrl() {
|
||||||
|
return backCoverArtUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setBackCoverArtUrl(String backCoverArtUrl) {
|
||||||
|
this.backCoverArtUrl = backCoverArtUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getUpcCode() {
|
||||||
|
return upcCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUpcCode(String upcCode) {
|
||||||
|
this.upcCode = upcCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
final int prime = 31;
|
||||||
|
int result = 1;
|
||||||
|
result = prime * result + ((backCoverArtUrl == null) ? 0 : backCoverArtUrl.hashCode());
|
||||||
|
result = prime * result + ((frontCoverArtUrl == null) ? 0 : frontCoverArtUrl.hashCode());
|
||||||
|
result = prime * result + ((upcCode == null) ? 0 : upcCode.hashCode());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if (this == obj)
|
||||||
|
return true;
|
||||||
|
if (obj == null)
|
||||||
|
return false;
|
||||||
|
if (getClass() != obj.getClass())
|
||||||
|
return false;
|
||||||
|
CoverArt other = (CoverArt) obj;
|
||||||
|
if (backCoverArtUrl == null) {
|
||||||
|
if (other.backCoverArtUrl != null)
|
||||||
|
return false;
|
||||||
|
} else if (!backCoverArtUrl.equals(other.backCoverArtUrl))
|
||||||
|
return false;
|
||||||
|
if (frontCoverArtUrl == null) {
|
||||||
|
if (other.frontCoverArtUrl != null)
|
||||||
|
return false;
|
||||||
|
} else if (!frontCoverArtUrl.equals(other.frontCoverArtUrl))
|
||||||
|
return false;
|
||||||
|
if (upcCode == null) {
|
||||||
|
if (other.upcCode != null)
|
||||||
|
return false;
|
||||||
|
} else if (!upcCode.equals(other.upcCode))
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
|
||||||
|
@SpringBootApplication
|
||||||
|
public class HibernateTypesApplication {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(HibernateTypesApplication.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,57 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import org.hibernate.annotations.Type;
|
||||||
|
import org.hibernate.annotations.TypeDef;
|
||||||
|
|
||||||
|
import java.time.YearMonth;
|
||||||
|
|
||||||
|
import javax.persistence.Column;
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
|
||||||
|
import com.vladmihalcea.hibernate.type.basic.YearMonthIntegerType;
|
||||||
|
|
||||||
|
@Entity(name = "Song")
|
||||||
|
@Table(name = "song")
|
||||||
|
@TypeDef(
|
||||||
|
typeClass = YearMonthIntegerType.class,
|
||||||
|
defaultForType = YearMonth.class
|
||||||
|
)
|
||||||
|
public class Song extends BaseEntity {
|
||||||
|
|
||||||
|
private Long length = 0L;
|
||||||
|
|
||||||
|
@Type(type = "json")
|
||||||
|
@Column(columnDefinition = "json")
|
||||||
|
private Artist artist;
|
||||||
|
|
||||||
|
@Column(
|
||||||
|
name = "recorded_on",
|
||||||
|
columnDefinition = "mediumint"
|
||||||
|
)
|
||||||
|
private YearMonth recordedOn = YearMonth.now();
|
||||||
|
|
||||||
|
public Long getLength() {
|
||||||
|
return length;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLength(Long length) {
|
||||||
|
this.length = length;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Artist getArtist() {
|
||||||
|
return artist;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setArtist(Artist artist) {
|
||||||
|
this.artist = artist;
|
||||||
|
}
|
||||||
|
|
||||||
|
public YearMonth getRecordedOn() {
|
||||||
|
return recordedOn;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setRecordedOn(YearMonth recordedOn) {
|
||||||
|
this.recordedOn = recordedOn;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import org.springframework.data.repository.CrudRepository;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface SongRepository extends CrudRepository<Song, Long> {
|
||||||
|
}
|
|
@ -0,0 +1,21 @@
|
||||||
|
log4jdbc.dump.sql.addsemicolon=true
|
||||||
|
log4jdbc.dump.sql.maxlinelength=0
|
||||||
|
log4jdbc.trim.sql.extrablanklines=false
|
||||||
|
logging.level.jdbc.audit=fatal
|
||||||
|
logging.level.jdbc.connection=fatal
|
||||||
|
logging.level.jdbc.resultset=fatal
|
||||||
|
logging.level.jdbc.resultsettable=info
|
||||||
|
logging.level.jdbc.sqlonly=fatal
|
||||||
|
logging.level.jdbc.sqltiming=info
|
||||||
|
# logging.level.org.hibernate.SQL=DEBUG
|
||||||
|
# logging.level.org.hibernate.type.descriptor.sql.BasicBinder=TRACE
|
||||||
|
# logging.level.org.hibernate.type.descriptor.sql=trace
|
||||||
|
# logging.level.org.springframework.jdbc.core.JdbcTemplate=DEBUG
|
||||||
|
# logging.level.org.springframework.jdbc.core.StatementCreatorUtils=TRACE
|
||||||
|
spring.datasource.url=jdbc:mysql://localhost:53306/hibernate_types?serverTimezone=UTC&useSSL=false
|
||||||
|
spring.datasource.username=root
|
||||||
|
spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect
|
||||||
|
spring.jpa.hibernate.ddl-auto=create
|
||||||
|
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
|
||||||
|
# spring.jpa.properties.hibernate.format_sql=false
|
||||||
|
# spring.jpa.show-sql=false
|
|
@ -0,0 +1 @@
|
||||||
|
hibernate.types.print.banner=false
|
|
@ -0,0 +1,182 @@
|
||||||
|
package com.baeldung.hibernate.types;
|
||||||
|
|
||||||
|
import com.google.common.collect.Lists;
|
||||||
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
|
||||||
|
import java.time.Duration;
|
||||||
|
import java.time.YearMonth;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
@SpringBootTest
|
||||||
|
public class HibernateTypesIntegrationTest {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
AlbumRepository albumRepository;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
SongRepository songRepository;
|
||||||
|
|
||||||
|
private void deleteAll() {
|
||||||
|
albumRepository.deleteAll();
|
||||||
|
songRepository.deleteAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
public void setUp() {
|
||||||
|
deleteAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
@BeforeEach
|
||||||
|
public void tearDown() {
|
||||||
|
setUp();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void hibernateTypeJsonTest() {
|
||||||
|
Album nullAlbum = new Album();
|
||||||
|
nullAlbum = albumRepository.save(nullAlbum);
|
||||||
|
|
||||||
|
Song nullSong = new Song();
|
||||||
|
nullSong = songRepository.save(nullSong);
|
||||||
|
|
||||||
|
Artist artist0 = new Artist();
|
||||||
|
artist0.setCountry("England");
|
||||||
|
artist0.setGenre("Pop");
|
||||||
|
artist0.setName("Superstar");
|
||||||
|
|
||||||
|
Song song0 = new Song();
|
||||||
|
song0.setArtist(artist0);
|
||||||
|
song0.setName("A Happy Song");
|
||||||
|
song0.setLength(Duration.ofMinutes(4).getSeconds());
|
||||||
|
song0 = songRepository.save(song0);
|
||||||
|
|
||||||
|
Song song1 = new Song();
|
||||||
|
song1.setArtist(artist0);
|
||||||
|
song1.setName("A Sad Song");
|
||||||
|
song1.setLength(Duration.ofMinutes(2).getSeconds());
|
||||||
|
song1 = songRepository.save(song1);
|
||||||
|
|
||||||
|
Song song2 = new Song();
|
||||||
|
song2.setArtist(artist0);
|
||||||
|
song2.setName("Another Happy Song");
|
||||||
|
song2.setLength(Duration.ofMinutes(3).getSeconds());
|
||||||
|
song2 = songRepository.save(song2);
|
||||||
|
|
||||||
|
Artist artist1 = new Artist();
|
||||||
|
artist1.setCountry("Jamaica");
|
||||||
|
artist1.setGenre("Reggae");
|
||||||
|
artist1.setName("Newcomer");
|
||||||
|
|
||||||
|
Song song3 = new Song();
|
||||||
|
song3.setArtist(artist1);
|
||||||
|
song3.setName("A New Song");
|
||||||
|
song3.setLength(Duration.ofMinutes(5).getSeconds());
|
||||||
|
song3 = songRepository.save(song3);
|
||||||
|
|
||||||
|
CoverArt album0CoverArt = new CoverArt();
|
||||||
|
album0CoverArt.setUpcCode(UUID.randomUUID().toString());
|
||||||
|
album0CoverArt.setFrontCoverArtUrl("http://fakeurl-0");
|
||||||
|
album0CoverArt.setBackCoverArtUrl("http://fakeurl-1");
|
||||||
|
|
||||||
|
Album album0 = new Album();
|
||||||
|
album0.setCoverArt(album0CoverArt);
|
||||||
|
album0.setName("Album 0");
|
||||||
|
album0.setSong(Lists.newArrayList(song0, song1, song2));
|
||||||
|
album0 = albumRepository.save(album0);
|
||||||
|
|
||||||
|
CoverArt album1CoverArt = new CoverArt();
|
||||||
|
album1CoverArt.setUpcCode(UUID.randomUUID().toString());
|
||||||
|
album1CoverArt.setFrontCoverArtUrl("http://fakeurl-2");
|
||||||
|
album1CoverArt.setBackCoverArtUrl("http://fakeurl-3");
|
||||||
|
|
||||||
|
Album album1 = new Album();
|
||||||
|
album1.setCoverArt(album1CoverArt);
|
||||||
|
album1.setName("Album 1");
|
||||||
|
album1.setSong(Lists.newArrayList(song3));
|
||||||
|
albumRepository.save(album1);
|
||||||
|
|
||||||
|
Iterable<Album> queryAlbumsResult = albumRepository.findAll();
|
||||||
|
assertThat(queryAlbumsResult).hasSize(3);
|
||||||
|
|
||||||
|
Iterable<Song> querySongsResult = songRepository.findAll();
|
||||||
|
assertThat(querySongsResult).hasSize(5);
|
||||||
|
|
||||||
|
Album queryAlbumResult;
|
||||||
|
|
||||||
|
queryAlbumResult = albumRepository.findById(nullAlbum.getId()).get();
|
||||||
|
assertThat(queryAlbumResult.getName()).isNull();
|
||||||
|
assertThat(queryAlbumResult.getCoverArt()).isNull();
|
||||||
|
assertThat(queryAlbumResult.getSongs()).isNullOrEmpty();
|
||||||
|
|
||||||
|
queryAlbumResult = albumRepository.findById(album0.getId()).get();
|
||||||
|
assertThat(queryAlbumResult.getName()).isEqualTo("Album 0");
|
||||||
|
assertThat(queryAlbumResult.getCoverArt().getFrontCoverArtUrl()).isEqualTo("http://fakeurl-0");
|
||||||
|
assertThat(queryAlbumResult.getCoverArt().getBackCoverArtUrl()).isEqualTo("http://fakeurl-1");
|
||||||
|
assertThat(queryAlbumResult.getSongs()).hasSize(3);
|
||||||
|
assertThat(queryAlbumResult.getSongs()).usingFieldByFieldElementComparator().containsExactlyInAnyOrder(song0, song1, song2);
|
||||||
|
|
||||||
|
queryAlbumResult = albumRepository.findById(album1.getId()).get();
|
||||||
|
assertThat(queryAlbumResult.getName()).isEqualTo("Album 1");
|
||||||
|
assertThat(queryAlbumResult.getCoverArt().getFrontCoverArtUrl()).isEqualTo("http://fakeurl-2");
|
||||||
|
assertThat(queryAlbumResult.getCoverArt().getBackCoverArtUrl()).isEqualTo("http://fakeurl-3");
|
||||||
|
assertThat(queryAlbumResult.getSongs()).hasSize(1);
|
||||||
|
assertThat(queryAlbumResult.getSongs()).usingFieldByFieldElementComparator().containsExactlyInAnyOrder(song3);
|
||||||
|
|
||||||
|
Song querySongResult;
|
||||||
|
|
||||||
|
querySongResult = songRepository.findById(nullSong.getId()).get();
|
||||||
|
assertThat(querySongResult.getName()).isNull();
|
||||||
|
assertThat(querySongResult.getLength()).isZero();
|
||||||
|
assertThat(querySongResult.getArtist()).isNull();
|
||||||
|
|
||||||
|
querySongResult = songRepository.findById(song0.getId()).get();
|
||||||
|
assertThat(querySongResult.getName()).isEqualTo("A Happy Song");
|
||||||
|
assertThat(querySongResult.getLength()).isEqualTo(Duration.ofMinutes(4).getSeconds());
|
||||||
|
assertThat(querySongResult.getArtist().getName()).isEqualTo("Superstar");
|
||||||
|
assertThat(querySongResult.getArtist().getGenre()).isEqualTo("Pop");
|
||||||
|
assertThat(querySongResult.getArtist().getCountry()).isEqualTo("England");
|
||||||
|
|
||||||
|
querySongResult = songRepository.findById(song1.getId()).get();
|
||||||
|
assertThat(querySongResult.getName()).isEqualTo("A Sad Song");
|
||||||
|
assertThat(querySongResult.getLength()).isEqualTo(Duration.ofMinutes(2).getSeconds());
|
||||||
|
assertThat(querySongResult.getArtist().getName()).isEqualTo("Superstar");
|
||||||
|
assertThat(querySongResult.getArtist().getGenre()).isEqualTo("Pop");
|
||||||
|
assertThat(querySongResult.getArtist().getCountry()).isEqualTo("England");
|
||||||
|
|
||||||
|
querySongResult = songRepository.findById(song2.getId()).get();
|
||||||
|
assertThat(querySongResult.getName()).isEqualTo("Another Happy Song");
|
||||||
|
assertThat(querySongResult.getLength()).isEqualTo(Duration.ofMinutes(3).getSeconds());
|
||||||
|
assertThat(querySongResult.getArtist().getName()).isEqualTo("Superstar");
|
||||||
|
assertThat(querySongResult.getArtist().getGenre()).isEqualTo("Pop");
|
||||||
|
assertThat(querySongResult.getArtist().getCountry()).isEqualTo("England");
|
||||||
|
|
||||||
|
querySongResult = songRepository.findById(song3.getId()).get();
|
||||||
|
assertThat(querySongResult.getName()).isEqualTo("A New Song");
|
||||||
|
assertThat(querySongResult.getLength()).isEqualTo(Duration.ofMinutes(5).getSeconds());
|
||||||
|
assertThat(querySongResult.getArtist().getName()).isEqualTo("Newcomer");
|
||||||
|
assertThat(querySongResult.getArtist().getGenre()).isEqualTo("Reggae");
|
||||||
|
assertThat(querySongResult.getArtist().getCountry()).isEqualTo("Jamaica");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void hibernateTypeYearMonthTest() {
|
||||||
|
Song mySong = new Song();
|
||||||
|
YearMonth now = YearMonth.of(2019, 12);
|
||||||
|
mySong.setArtist(new Artist());
|
||||||
|
mySong.setName("My Song");
|
||||||
|
mySong.setLength(Duration.ofMinutes(1).getSeconds());
|
||||||
|
mySong.setRecordedOn(now);
|
||||||
|
mySong = songRepository.save(mySong);
|
||||||
|
|
||||||
|
Song queryResult;
|
||||||
|
queryResult = songRepository.findById(mySong.getId()).get();
|
||||||
|
assertThat(queryResult.getRecordedOn().getYear()).isEqualTo(2019);
|
||||||
|
assertThat(queryResult.getRecordedOn().getMonthValue()).isEqualTo(12);
|
||||||
|
}
|
||||||
|
}
|
|
@ -24,6 +24,7 @@
|
||||||
<module>hibernate-mapping</module> <!-- long running -->
|
<module>hibernate-mapping</module> <!-- long running -->
|
||||||
<module>hibernate-ogm</module>
|
<module>hibernate-ogm</module>
|
||||||
<module>hibernate-annotations</module>
|
<module>hibernate-annotations</module>
|
||||||
|
<module>hibernate-types</module>
|
||||||
<module>hibernate-jpa</module>
|
<module>hibernate-jpa</module>
|
||||||
<module>hibernate-queries</module>
|
<module>hibernate-queries</module>
|
||||||
<module>hibernate-enterprise</module>
|
<module>hibernate-enterprise</module>
|
||||||
|
|
Loading…
Reference in New Issue