Java example for Hibernate Types
This commit is contained in:
		
							parent
							
								
									646bd45c18
								
							
						
					
					
						commit
						925a69b401
					
				
							
								
								
									
										33
									
								
								persistence-modules/hibernate-types/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								persistence-modules/hibernate-types/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -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/ | ||||||
							
								
								
									
										7
									
								
								persistence-modules/hibernate-types/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								persistence-modules/hibernate-types/README.md
									
									
									
									
									
										Normal file
									
								
							| @ -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/) | ||||||
							
								
								
									
										19
									
								
								persistence-modules/hibernate-types/docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								persistence-modules/hibernate-types/docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							| @ -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 | ||||||
							
								
								
									
										214
									
								
								persistence-modules/hibernate-types/pom.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										214
									
								
								persistence-modules/hibernate-types/pom.xml
									
									
									
									
									
										Normal file
									
								
							| @ -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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user