BAEL-592: Cleanup and refactor (#1823)
* Add files via upload * Update pom.xml * Update RunGuice.java * Update Communication.java * Update CommunicationMode.java * Update DefaultCommunicator.java * Update EmailCommunicationMode.java * Update IMCommunicationMode.java * Update SMSCommunicationMode.java * Update MessageLogger.java * Update MessageSentLoggable.java * Update AOPModule.java * Update BasicModule.java * Update CommunicationModel.java * Update Communicator.java * Update BasicModule.java * Update RunGuice.java * Update MessageLogger.java * Update Communicator.java * Update pom.xml * BAEL-278: Updated README.md * BAEL-554: Add and update README.md files * Update pom.xml * Update pom.xml * Update pom.xml * BAEL-345: fixed assertion * BAEL-109: Updated README.md * BAEL-345: Added README.md * Reinstating reactor-core module in root-level pom * BAEL-393: Adding guide-intro module to root pom * BAEL-9: Updated README.md * BAEL-157: README.md updated * Changed project name * Update RunGuice.java Removed references to message logging and output * Update Communication.java Removed message logging-related code * BAEL-566: Updated README.md * New project name * BAEL-393: removing guice-intro directory * BAEL-393: renamed module guice-intro to guice in root pom.xml * BAEL-393 and BAEL-541 README.md files * BAEL-731: Updated README.md * BAEL-680: renamed test methods * BAEL-714: Updated README.md * BAEL-737: Updated README.md * BAEL-680 and BAEL-756 README.md updates * BAEL-666: Updated README * BAEL-415: Custom Scope * BAEL-415: Custom Scope - renamed classes to reflect TenantScope * README file updates for BAEL-723, BAEL-763, and BAEL-415 * BAEL-735: README * BAEL-567: README * BAEL-736: README * BAEL-766: Update README * BAEL-555: README update * BAEL-761: README update * BAEL-742: Stripe API for Java README file * BAEL-86: Correction to README file * BAEL-828: Updated README.md * BAEL-830: Updated README * BAEL-870: Switched from TestNG to JUnit due to build errors * BAEL-870: Update README * BAEL-592: Cleanup files that were copied from spring-hibernate4 module * BAEL-592: Cleanup files that were copied from spring-hibernate4 module and add new basic test
This commit is contained in:
parent
7b93d18a2d
commit
9ec6e18552
@ -33,11 +33,6 @@
|
|||||||
<artifactId>spring-aspects</artifactId>
|
<artifactId>spring-aspects</artifactId>
|
||||||
<version>${org.springframework.version}</version>
|
<version>${org.springframework.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.security</groupId>
|
|
||||||
<artifactId>spring-security-core</artifactId>
|
|
||||||
<version>${org.springframework.security.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- persistence -->
|
<!-- persistence -->
|
||||||
|
|
||||||
@ -56,21 +51,11 @@
|
|||||||
<artifactId>hibernate-core</artifactId>
|
<artifactId>hibernate-core</artifactId>
|
||||||
<version>${hibernate.version}</version>
|
<version>${hibernate.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>org.hibernate</groupId>
|
|
||||||
<artifactId>hibernate-envers</artifactId>
|
|
||||||
<version>${hibernate-envers.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>javax.transaction</groupId>
|
<groupId>javax.transaction</groupId>
|
||||||
<artifactId>jta</artifactId>
|
<artifactId>jta</artifactId>
|
||||||
<version>${jta.version}</version>
|
<version>${jta.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>mysql</groupId>
|
|
||||||
<artifactId>mysql-connector-java</artifactId>
|
|
||||||
<version>${mysql-connector-java.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.tomcat</groupId>
|
<groupId>org.apache.tomcat</groupId>
|
||||||
@ -80,17 +65,6 @@
|
|||||||
|
|
||||||
<!-- validation -->
|
<!-- validation -->
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.hibernate</groupId>
|
|
||||||
<artifactId>hibernate-validator</artifactId>
|
|
||||||
<version>${hibernate-validator.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>javax.el</groupId>
|
|
||||||
<artifactId>javax.el-api</artifactId>
|
|
||||||
<version>${javax.el-api.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- utils -->
|
<!-- utils -->
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
@ -115,6 +89,11 @@
|
|||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hamcrest</groupId>
|
||||||
|
<artifactId>hamcrest-core</artifactId>
|
||||||
|
<version>${org.hamcrest.version}</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework.security</groupId>
|
<groupId>org.springframework.security</groupId>
|
||||||
<artifactId>spring-security-test</artifactId>
|
<artifactId>spring-security-test</artifactId>
|
||||||
@ -129,12 +108,25 @@
|
|||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hamcrest</groupId>
|
||||||
|
<artifactId>hamcrest-library</artifactId>
|
||||||
|
<version>${org.hamcrest.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.hsqldb</groupId>
|
<groupId>org.hsqldb</groupId>
|
||||||
<artifactId>hsqldb</artifactId>
|
<artifactId>hsqldb</artifactId>
|
||||||
<version>${hsqldb.version}</version>
|
<version>${hsqldb.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.h2database</groupId>
|
||||||
|
<artifactId>h2</artifactId>
|
||||||
|
<version>${h2.version}</version>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
@ -146,21 +138,54 @@
|
|||||||
</resource>
|
</resource>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
||||||
|
<plugins>
|
||||||
|
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-compiler-plugin</artifactId>
|
||||||
|
<version>${maven-compiler-plugin.version}</version>
|
||||||
|
<configuration>
|
||||||
|
<source>1.8</source>
|
||||||
|
<target>1.8</target>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
|
<version>${maven-surefire-plugin.version}</version>
|
||||||
|
<configuration>
|
||||||
|
<excludes>
|
||||||
|
<exclude>**/*IntegrationTest.java</exclude>
|
||||||
|
</excludes>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
|
||||||
|
</plugins>
|
||||||
|
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<!-- Spring -->
|
<!-- Spring -->
|
||||||
<org.springframework.version>4.3.5.RELEASE</org.springframework.version>
|
<org.springframework.version>4.3.5.RELEASE</org.springframework.version>
|
||||||
|
|
||||||
|
<org.springframework.data.version>1.10.6.RELEASE</org.springframework.data.version>
|
||||||
|
|
||||||
<org.springframework.security.version>4.2.1.RELEASE</org.springframework.security.version>
|
<org.springframework.security.version>4.2.1.RELEASE</org.springframework.security.version>
|
||||||
<org.springframework.data.version>1.10.6.RELEASE</org.springframework.data.version>
|
<org.springframework.data.version>1.10.6.RELEASE</org.springframework.data.version>
|
||||||
|
|
||||||
|
|
||||||
<!-- persistence -->
|
<!-- persistence -->
|
||||||
<hibernate.version>5.2.8.Final</hibernate.version>
|
<hibernate.version>5.2.10.Final</hibernate.version>
|
||||||
<hibernate-envers.version>${hibernate.version}</hibernate-envers.version>
|
<tomcat-dbcp.version>8.5.15</tomcat-dbcp.version>
|
||||||
<mysql-connector-java.version>6.0.5</mysql-connector-java.version>
|
|
||||||
<tomcat-dbcp.version>8.5.11</tomcat-dbcp.version>
|
|
||||||
<jta.version>1.1</jta.version>
|
<jta.version>1.1</jta.version>
|
||||||
<hsqldb.version>2.3.4</hsqldb.version>
|
<hsqldb.version>2.3.4</hsqldb.version>
|
||||||
|
<h2.version>1.4.195</h2.version>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- logging -->
|
||||||
|
<org.slf4j.version>1.7.21</org.slf4j.version>
|
||||||
|
<logback.version>1.1.7</logback.version>
|
||||||
|
|
||||||
<!-- various -->
|
<!-- various -->
|
||||||
<hibernate-validator.version>5.4.0.Final</hibernate-validator.version>
|
<hibernate-validator.version>5.4.0.Final</hibernate-validator.version>
|
||||||
@ -170,6 +195,11 @@
|
|||||||
<guava.version>21.0</guava.version>
|
<guava.version>21.0</guava.version>
|
||||||
<commons-lang3.version>3.5</commons-lang3.version>
|
<commons-lang3.version>3.5</commons-lang3.version>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- testing -->
|
||||||
|
<org.hamcrest.version>1.3</org.hamcrest.version>
|
||||||
|
<junit.version>4.12</junit.version>
|
||||||
|
|
||||||
<httpcore.version>4.4.1</httpcore.version>
|
<httpcore.version>4.4.1</httpcore.version>
|
||||||
<httpclient.version>4.5</httpclient.version>
|
<httpclient.version>4.5</httpclient.version>
|
||||||
|
|
||||||
|
@ -1,81 +0,0 @@
|
|||||||
package com.baeldung.hibernate.criteria.model;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
public class Item implements Serializable {
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
private Integer itemId;
|
|
||||||
private String itemName;
|
|
||||||
private String itemDescription;
|
|
||||||
private Integer itemPrice;
|
|
||||||
|
|
||||||
// constructors
|
|
||||||
public Item() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public Item(final Integer itemId, final String itemName, final String itemDescription) {
|
|
||||||
super();
|
|
||||||
this.itemId = itemId;
|
|
||||||
this.itemName = itemName;
|
|
||||||
this.itemDescription = itemDescription;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((itemId == null) ? 0 : itemId.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final Item other = (Item) obj;
|
|
||||||
if (itemId == null) {
|
|
||||||
if (other.itemId != null)
|
|
||||||
return false;
|
|
||||||
} else if (!itemId.equals(other.itemId))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Integer getItemId() {
|
|
||||||
return itemId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setItemId(final Integer itemId) {
|
|
||||||
this.itemId = itemId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getItemName() {
|
|
||||||
return itemName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setItemName(final String itemName) {
|
|
||||||
this.itemName = itemName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getItemDescription() {
|
|
||||||
return itemDescription;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Integer getItemPrice() {
|
|
||||||
return itemPrice;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setItemPrice(final Integer itemPrice) {
|
|
||||||
this.itemPrice = itemPrice;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setItemDescription(final String itemDescription) {
|
|
||||||
this.itemDescription = itemDescription;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
package com.baeldung.hibernate.criteria.util;
|
|
||||||
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.hibernate.cfg.Configuration;
|
|
||||||
|
|
||||||
public class HibernateUtil {
|
|
||||||
|
|
||||||
public static Session getHibernateSession() {
|
|
||||||
|
|
||||||
final SessionFactory sf = new Configuration().configure("criteria.cfg.xml").buildSessionFactory();
|
|
||||||
|
|
||||||
final Session session = sf.openSession();
|
|
||||||
return session;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,279 +0,0 @@
|
|||||||
/**
|
|
||||||
* ApplicationViewer is the class that starts the application
|
|
||||||
* First it creates the session object and then creates the
|
|
||||||
* criteria query.
|
|
||||||
*
|
|
||||||
* @author Sandeep Kumar
|
|
||||||
* @version 1.0
|
|
||||||
* @since 01/13/2017
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.baeldung.hibernate.criteria.view;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.persistence.Tuple;
|
|
||||||
import javax.persistence.criteria.CriteriaBuilder;
|
|
||||||
import javax.persistence.criteria.CriteriaQuery;
|
|
||||||
import javax.persistence.criteria.Order;
|
|
||||||
import javax.persistence.criteria.Predicate;
|
|
||||||
import javax.persistence.criteria.Root;
|
|
||||||
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.Transaction;
|
|
||||||
|
|
||||||
import com.baeldung.hibernate.criteria.model.Item;
|
|
||||||
import com.baeldung.hibernate.criteria.util.HibernateUtil;
|
|
||||||
|
|
||||||
public class ApplicationView {
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public boolean checkIfCriteriaTimeLower() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
Transaction tx = null;
|
|
||||||
|
|
||||||
// calculate the time taken by criteria
|
|
||||||
final long startTimeCriteria = System.nanoTime();
|
|
||||||
criteriaItem.select(rootItem).where(builder.like(rootItem.get("itemName"), "%item One%"));
|
|
||||||
final List<Item> results = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final long endTimeCriteria = System.nanoTime();
|
|
||||||
final long durationCriteria = (endTimeCriteria - startTimeCriteria) / 1000;
|
|
||||||
|
|
||||||
// calculate the time taken by HQL
|
|
||||||
final long startTimeHQL = System.nanoTime();
|
|
||||||
tx = session.beginTransaction();
|
|
||||||
final List<Item> items = session.createQuery("FROM Item where itemName like '%item One%'").getResultList();
|
|
||||||
final long endTimeHQL = System.nanoTime();
|
|
||||||
final long durationHQL = (endTimeHQL - startTimeHQL) / 1000;
|
|
||||||
|
|
||||||
if (durationCriteria > durationHQL) {
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get items having price more than 1000
|
|
||||||
public String[] greaterThanCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.greaterThan(rootItem.get("itemPrice"), 1000));
|
|
||||||
final List<Item> greaterThanItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String greaterThanItems[] = new String[greaterThanItemsList.size()];
|
|
||||||
for (int i = 0; i < greaterThanItemsList.size(); i++) {
|
|
||||||
greaterThanItems[i] = greaterThanItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return greaterThanItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get items having price less than 1000
|
|
||||||
public String[] lessThanCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.lessThan(rootItem.get("itemPrice"), 1000));
|
|
||||||
final List<Item> lessThanItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String lessThanItems[] = new String[lessThanItemsList.size()];
|
|
||||||
for (int i = 0; i < lessThanItemsList.size(); i++) {
|
|
||||||
lessThanItems[i] = lessThanItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return lessThanItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get items whose Name start with Chair
|
|
||||||
public String[] likeCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.like(rootItem.get("itemName"), "%chair%"));
|
|
||||||
final List<Item> likeItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String likeItems[] = new String[likeItemsList.size()];
|
|
||||||
for (int i = 0; i < likeItemsList.size(); i++) {
|
|
||||||
likeItems[i] = likeItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return likeItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Case sensitive search
|
|
||||||
public String[] likeCaseCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.like(rootItem.get("itemName"), "%Chair%"));
|
|
||||||
final List<Item> ilikeItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String ilikeItems[] = new String[ilikeItemsList.size()];
|
|
||||||
for (int i = 0; i < ilikeItemsList.size(); i++) {
|
|
||||||
ilikeItems[i] = ilikeItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return ilikeItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get records having itemPrice in between 100 and 200
|
|
||||||
public String[] betweenCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
// To get items having price more than 1000
|
|
||||||
criteriaItem.select(rootItem).where(builder.between(rootItem.get("itemPrice"), 100, 200));
|
|
||||||
final List<Item> betweenItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String betweenItems[] = new String[betweenItemsList.size()];
|
|
||||||
for (int i = 0; i < betweenItemsList.size(); i++) {
|
|
||||||
betweenItems[i] = betweenItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return betweenItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To check if the given property is null
|
|
||||||
public String[] nullCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.isNull(rootItem.get("itemDescription")));
|
|
||||||
final List<Item> nullItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String nullDescItems[] = new String[nullItemsList.size()];
|
|
||||||
for (int i = 0; i < nullItemsList.size(); i++) {
|
|
||||||
nullDescItems[i] = nullItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return nullDescItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To check if the given property is not null
|
|
||||||
public String[] notNullCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.isNotNull(rootItem.get("itemDescription")));
|
|
||||||
final List<Item> notNullItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String notNullDescItems[] = new String[notNullItemsList.size()];
|
|
||||||
for (int i = 0; i < notNullItemsList.size(); i++) {
|
|
||||||
notNullDescItems[i] = notNullItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return notNullDescItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Adding more than one expression in one cr
|
|
||||||
public String[] twoCriteria() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.select(rootItem).where(builder.isNull(rootItem.get("itemDescription"))).where(builder.like(rootItem.get("itemName"), "chair%"));
|
|
||||||
final List<Item> notNullItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String notNullDescItems[] = new String[notNullItemsList.size()];
|
|
||||||
for (int i = 0; i < notNullItemsList.size(); i++) {
|
|
||||||
notNullDescItems[i] = notNullItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return notNullDescItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get items matching with the above defined conditions joined
|
|
||||||
// with Logical AND
|
|
||||||
public String[] andLogicalCriteria() {
|
|
||||||
List<Predicate> predicates = new ArrayList<Predicate>();
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
predicates.add(builder.greaterThan(rootItem.get("itemPrice"), 1000));
|
|
||||||
predicates.add(builder.like(rootItem.get("itemName"), "Chair%"));
|
|
||||||
Predicate andPredicate = builder.and(predicates.toArray(new Predicate[] {}));
|
|
||||||
criteriaItem.select(rootItem).where(andPredicate);
|
|
||||||
final List<Item> andItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String andItems[] = new String[andItemsList.size()];
|
|
||||||
for (int i = 0; i < andItemsList.size(); i++) {
|
|
||||||
andItems[i] = andItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return andItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// To get items matching with the above defined conditions joined
|
|
||||||
// with Logical OR
|
|
||||||
public String[] orLogicalCriteria() {
|
|
||||||
List<Predicate> predicates = new ArrayList<Predicate>();
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
predicates.add(builder.greaterThan(rootItem.get("itemPrice"), 1000));
|
|
||||||
predicates.add(builder.like(rootItem.get("itemName"), "Chair%"));
|
|
||||||
Predicate orPredicate = builder.or(predicates.toArray(new Predicate[] {}));
|
|
||||||
criteriaItem.select(rootItem).where(orPredicate);
|
|
||||||
final List<Item> orItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String orItems[] = new String[orItemsList.size()];
|
|
||||||
for (int i = 0; i < orItemsList.size(); i++) {
|
|
||||||
orItems[i] = orItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return orItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sorting example
|
|
||||||
public String[] sortingCriteria() {
|
|
||||||
List<Order> listOrders = new ArrayList<Order>();
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Item> criteriaItem = builder.createQuery(Item.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
listOrders.add(builder.asc(rootItem.get("itemName")));
|
|
||||||
listOrders.add(builder.desc(rootItem.get("itemPrice")));
|
|
||||||
criteriaItem.orderBy(listOrders.toArray(new Order[] {}));
|
|
||||||
final List<Item> sortedItemsList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final String sortedItems[] = new String[sortedItemsList.size()];
|
|
||||||
for (int i = 0; i < sortedItemsList.size(); i++) {
|
|
||||||
sortedItems[i] = sortedItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
return sortedItems;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set projections Row Count
|
|
||||||
public Long[] projectionRowCount() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Tuple> criteriaItem = builder.createQuery(Tuple.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.multiselect(builder.count(rootItem));
|
|
||||||
final List<Tuple> itemProjected = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final Long projectedRowCount[] = new Long[1];
|
|
||||||
projectedRowCount[0] = (long) itemProjected.get(0).get(0);
|
|
||||||
session.close();
|
|
||||||
return projectedRowCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set projections average of itemPrice
|
|
||||||
public Double[] projectionAverage() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Tuple> criteriaItem = builder.createQuery(Tuple.class);
|
|
||||||
Root<Item> rootItem = criteriaItem.from(Item.class);
|
|
||||||
criteriaItem.multiselect(builder.avg(rootItem.get("itemPrice")));
|
|
||||||
final List<Tuple> itemProjected = session.createQuery(criteriaItem).getResultList();
|
|
||||||
Double avgItemPrice[] = new Double[1];
|
|
||||||
avgItemPrice[0] = Double.valueOf(itemProjected.get(0).get(0).toString());
|
|
||||||
session.close();
|
|
||||||
return avgItemPrice;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,58 +0,0 @@
|
|||||||
package com.baeldung.hibernate.fetching.model;
|
|
||||||
|
|
||||||
import javax.persistence.*;
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.sql.Date;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "USER_ORDER")
|
|
||||||
public class OrderDetail implements Serializable {
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue
|
|
||||||
@Column(name = "ORDER_ID")
|
|
||||||
private Long orderId;
|
|
||||||
|
|
||||||
public OrderDetail() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public OrderDetail(Date orderDate, String orderDesc) {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((orderId == null) ? 0 : orderId.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;
|
|
||||||
OrderDetail other = (OrderDetail) obj;
|
|
||||||
if (orderId == null) {
|
|
||||||
if (other.orderId != null)
|
|
||||||
return false;
|
|
||||||
} else if (!orderId.equals(other.orderId))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getOrderId() {
|
|
||||||
return orderId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setOrderId(Long orderId) {
|
|
||||||
this.orderId = orderId;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,71 +0,0 @@
|
|||||||
package com.baeldung.hibernate.fetching.model;
|
|
||||||
|
|
||||||
import javax.persistence.*;
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "USER")
|
|
||||||
public class UserEager implements Serializable {
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue
|
|
||||||
@Column(name = "USER_ID")
|
|
||||||
private Long userId;
|
|
||||||
|
|
||||||
@OneToMany(fetch = FetchType.EAGER, mappedBy = "user")
|
|
||||||
private Set<OrderDetail> orderDetail = new HashSet<OrderDetail>();
|
|
||||||
|
|
||||||
public UserEager() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public UserEager(final Long userId) {
|
|
||||||
super();
|
|
||||||
this.userId = userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((userId == null) ? 0 : userId.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final UserEager other = (UserEager) obj;
|
|
||||||
if (userId == null) {
|
|
||||||
if (other.userId != null)
|
|
||||||
return false;
|
|
||||||
} else if (!userId.equals(other.userId))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getUserId() {
|
|
||||||
return userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUserId(final Long userId) {
|
|
||||||
this.userId = userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Set<OrderDetail> getOrderDetail() {
|
|
||||||
return orderDetail;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setOrderDetail(Set<OrderDetail> orderDetail) {
|
|
||||||
this.orderDetail = orderDetail;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,71 +0,0 @@
|
|||||||
package com.baeldung.hibernate.fetching.model;
|
|
||||||
|
|
||||||
import javax.persistence.*;
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@Table(name = "USER")
|
|
||||||
public class UserLazy implements Serializable {
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue
|
|
||||||
@Column(name = "USER_ID")
|
|
||||||
private Long userId;
|
|
||||||
|
|
||||||
@OneToMany(fetch = FetchType.LAZY, mappedBy = "user")
|
|
||||||
private Set<OrderDetail> orderDetail = new HashSet<OrderDetail>();
|
|
||||||
|
|
||||||
public UserLazy() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public UserLazy(final Long userId) {
|
|
||||||
super();
|
|
||||||
this.userId = userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((userId == null) ? 0 : userId.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final UserLazy other = (UserLazy) obj;
|
|
||||||
if (userId == null) {
|
|
||||||
if (other.userId != null)
|
|
||||||
return false;
|
|
||||||
} else if (!userId.equals(other.userId))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Long getUserId() {
|
|
||||||
return userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setUserId(final Long userId) {
|
|
||||||
this.userId = userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Set<OrderDetail> getOrderDetail() {
|
|
||||||
return orderDetail;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setOrderDetail(Set<OrderDetail> orderDetail) {
|
|
||||||
this.orderDetail = orderDetail;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
package com.baeldung.hibernate.fetching.util;
|
|
||||||
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.hibernate.cfg.Configuration;
|
|
||||||
|
|
||||||
public class HibernateUtil {
|
|
||||||
|
|
||||||
public static Session getHibernateSession(String fetchMethod) {
|
|
||||||
// two config files are there
|
|
||||||
// one with lazy loading enabled
|
|
||||||
// another lazy = false
|
|
||||||
SessionFactory sf;
|
|
||||||
if ("lazy".equals(fetchMethod)) {
|
|
||||||
sf = new Configuration().configure("fetchingLazy.cfg.xml").buildSessionFactory();
|
|
||||||
} else {
|
|
||||||
sf = new Configuration().configure("fetching.cfg.xml").buildSessionFactory();
|
|
||||||
}
|
|
||||||
|
|
||||||
// fetching.cfg.xml is used for this example
|
|
||||||
return sf.openSession();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Session getHibernateSession() {
|
|
||||||
return new Configuration().configure("fetching.cfg.xml").buildSessionFactory().openSession();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,68 +0,0 @@
|
|||||||
package com.baeldung.hibernate.fetching.view;
|
|
||||||
|
|
||||||
import com.baeldung.hibernate.fetching.model.OrderDetail;
|
|
||||||
import com.baeldung.hibernate.fetching.model.UserEager;
|
|
||||||
import com.baeldung.hibernate.fetching.model.UserLazy;
|
|
||||||
import com.baeldung.hibernate.fetching.util.HibernateUtil;
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.Transaction;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
public class FetchingAppView {
|
|
||||||
|
|
||||||
public FetchingAppView() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// lazily loaded
|
|
||||||
public Set<OrderDetail> lazyLoaded() {
|
|
||||||
final Session sessionLazy = HibernateUtil.getHibernateSession("lazy");
|
|
||||||
List<UserLazy> users = sessionLazy.createQuery("From UserLazy").getResultList();
|
|
||||||
UserLazy userLazyLoaded = users.get(3);
|
|
||||||
// since data is lazyloaded so data won't be initialized
|
|
||||||
return (userLazyLoaded.getOrderDetail());
|
|
||||||
}
|
|
||||||
|
|
||||||
// eagerly loaded
|
|
||||||
public Set<OrderDetail> eagerLoaded() {
|
|
||||||
final Session sessionEager = HibernateUtil.getHibernateSession();
|
|
||||||
// data should be loaded in the following line
|
|
||||||
// also note the queries generated
|
|
||||||
List<UserEager> user = sessionEager.createQuery("From UserEager").getResultList();
|
|
||||||
UserEager userEagerLoaded = user.get(3);
|
|
||||||
return userEagerLoaded.getOrderDetail();
|
|
||||||
}
|
|
||||||
|
|
||||||
// creates test data
|
|
||||||
// call this method to create the data in the database
|
|
||||||
public void createTestData() {
|
|
||||||
|
|
||||||
final Session session = HibernateUtil.getHibernateSession("lazy");
|
|
||||||
Transaction tx = session.beginTransaction();
|
|
||||||
final UserLazy user1 = new UserLazy();
|
|
||||||
final UserLazy user2 = new UserLazy();
|
|
||||||
final UserLazy user3 = new UserLazy();
|
|
||||||
|
|
||||||
session.save(user1);
|
|
||||||
session.save(user2);
|
|
||||||
session.save(user3);
|
|
||||||
|
|
||||||
final OrderDetail order1 = new OrderDetail();
|
|
||||||
final OrderDetail order2 = new OrderDetail();
|
|
||||||
final OrderDetail order3 = new OrderDetail();
|
|
||||||
final OrderDetail order4 = new OrderDetail();
|
|
||||||
final OrderDetail order5 = new OrderDetail();
|
|
||||||
|
|
||||||
session.saveOrUpdate(order1);
|
|
||||||
session.saveOrUpdate(order2);
|
|
||||||
session.saveOrUpdate(order3);
|
|
||||||
session.saveOrUpdate(order4);
|
|
||||||
session.saveOrUpdate(order5);
|
|
||||||
|
|
||||||
tx.commit();
|
|
||||||
session.close();
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
|
|
||||||
public interface IBarAuditableDao extends IBarDao, IAuditOperations<Bar> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import org.springframework.data.repository.CrudRepository;
|
|
||||||
|
|
||||||
public interface IBarCrudRepository extends CrudRepository<Bar, Serializable> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
|
|
||||||
public interface IBarDao extends IOperations<Bar> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Child;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
|
|
||||||
public interface IChildDao extends IOperations<Child> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
|
|
||||||
public interface IFooAuditableDao extends IFooDao, IAuditOperations<Foo> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Parent;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
|
|
||||||
public interface IParentDao extends IOperations<Parent> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,37 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.hibernate.envers.AuditReader;
|
|
||||||
import org.hibernate.envers.AuditReaderFactory;
|
|
||||||
import org.hibernate.envers.query.AuditQuery;
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public class AbstractHibernateAuditableDao<T extends Serializable> extends AbstractHibernateDao<T> implements IAuditOperations<T> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> getEntitiesAtRevision(final Number revision) {
|
|
||||||
final AuditReader auditReader = AuditReaderFactory.get(getCurrentSession());
|
|
||||||
final AuditQuery query = auditReader.createQuery().forEntitiesAtRevision(clazz, revision);
|
|
||||||
final List<T> resultList = query.getResultList();
|
|
||||||
return resultList;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> getEntitiesModifiedAtRevision(final Number revision) {
|
|
||||||
final AuditReader auditReader = AuditReaderFactory.get(getCurrentSession());
|
|
||||||
final AuditQuery query = auditReader.createQuery().forEntitiesModifiedAtRevision(clazz, revision);
|
|
||||||
final List<T> resultList = query.getResultList();
|
|
||||||
return resultList;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> getRevisions() {
|
|
||||||
final AuditReader auditReader = AuditReaderFactory.get(getCurrentSession());
|
|
||||||
final AuditQuery query = auditReader.createQuery().forRevisionsOfEntity(clazz, true, true);
|
|
||||||
final List<T> resultList = query.getResultList();
|
|
||||||
return resultList;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,56 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
|
||||||
import javax.persistence.PersistenceContext;
|
|
||||||
import javax.persistence.TypedQuery;
|
|
||||||
import javax.persistence.criteria.CriteriaBuilder;
|
|
||||||
import javax.persistence.criteria.CriteriaQuery;
|
|
||||||
import javax.persistence.criteria.Root;
|
|
||||||
|
|
||||||
public class AbstractJpaDao<T extends Serializable> extends AbstractDao<T> implements IOperations<T> {
|
|
||||||
|
|
||||||
@PersistenceContext
|
|
||||||
private EntityManager em;
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T findOne(final long id) {
|
|
||||||
return em.find(clazz, Long.valueOf(id).intValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> findAll() {
|
|
||||||
final CriteriaBuilder cb = em.getCriteriaBuilder();
|
|
||||||
final CriteriaQuery<T> cq = cb.createQuery(clazz);
|
|
||||||
final Root<T> rootEntry = cq.from(clazz);
|
|
||||||
final CriteriaQuery<T> all = cq.select(rootEntry);
|
|
||||||
final TypedQuery<T> allQuery = em.createQuery(all);
|
|
||||||
return allQuery.getResultList();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void create(final T entity) {
|
|
||||||
em.persist(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T update(final T entity) {
|
|
||||||
em.merge(entity);
|
|
||||||
return entity;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void delete(final T entity) {
|
|
||||||
em.remove(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteById(final long entityId) {
|
|
||||||
delete(findOne(entityId));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.config.BeanDefinition;
|
|
||||||
import org.springframework.context.annotation.Scope;
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
@Repository
|
|
||||||
@Scope(BeanDefinition.SCOPE_PROTOTYPE)
|
|
||||||
public class GenericHibernateDao<T extends Serializable> extends AbstractHibernateDao<T> implements IGenericDao<T> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,14 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public interface IAuditOperations<T extends Serializable> {
|
|
||||||
|
|
||||||
List<T> getEntitiesAtRevision(Number revision);
|
|
||||||
|
|
||||||
List<T> getEntitiesModifiedAtRevision(Number revision);
|
|
||||||
|
|
||||||
List<T> getRevisions();
|
|
||||||
|
|
||||||
}
|
|
@ -1,7 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
public interface IGenericDao<T extends Serializable> extends IOperations<T> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.impl;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IBarAuditableDao;
|
|
||||||
import com.baeldung.persistence.dao.common.AbstractHibernateAuditableDao;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
|
|
||||||
public class BarAuditableDao extends AbstractHibernateAuditableDao<Bar> implements IBarAuditableDao {
|
|
||||||
|
|
||||||
public BarAuditableDao() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
setClazz(Bar.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<Bar> getRevisions() {
|
|
||||||
final List<Bar> resultList = super.getRevisions();
|
|
||||||
for (final Bar bar : resultList) {
|
|
||||||
bar.getFooSet().size(); // force FooSet initialization
|
|
||||||
}
|
|
||||||
return resultList;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.AbstractHibernateDao;
|
|
||||||
import com.baeldung.persistence.dao.IBarDao;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
@Repository
|
|
||||||
public class BarDao extends AbstractHibernateDao<Bar> implements IBarDao {
|
|
||||||
|
|
||||||
public BarDao() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
setClazz(Bar.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IBarDao;
|
|
||||||
import com.baeldung.persistence.dao.common.AbstractJpaDao;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
@Repository
|
|
||||||
public class BarJpaDao extends AbstractJpaDao<Bar> implements IBarDao {
|
|
||||||
|
|
||||||
public BarJpaDao() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
setClazz(Bar.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
}
|
|
@ -1,19 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.AbstractHibernateDao;
|
|
||||||
import com.baeldung.persistence.model.Child;
|
|
||||||
import com.baeldung.persistence.dao.IChildDao;
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
@Repository
|
|
||||||
public class ChildDao extends AbstractHibernateDao<Child> implements IChildDao {
|
|
||||||
|
|
||||||
public ChildDao() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
setClazz(Child.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
}
|
|
@ -1,17 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.AbstractHibernateAuditableDao;
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.persistence.dao.IFooAuditableDao;
|
|
||||||
|
|
||||||
public class FooAuditableDao extends AbstractHibernateAuditableDao<Foo> implements IFooAuditableDao {
|
|
||||||
|
|
||||||
public FooAuditableDao() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
setClazz(Foo.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
}
|
|
@ -6,9 +6,9 @@ import com.baeldung.persistence.model.Foo;
|
|||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
@Repository
|
@Repository
|
||||||
public class FooDao extends AbstractHibernateDao<Foo> implements IFooDao {
|
public class FooHibernateDao extends AbstractHibernateDao<Foo> implements IFooDao {
|
||||||
|
|
||||||
public FooDao() {
|
public FooHibernateDao() {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
setClazz(Foo.class);
|
setClazz(Foo.class);
|
@ -1,19 +0,0 @@
|
|||||||
package com.baeldung.persistence.dao.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IParentDao;
|
|
||||||
import com.baeldung.persistence.dao.common.AbstractHibernateDao;
|
|
||||||
import com.baeldung.persistence.model.Parent;
|
|
||||||
import org.springframework.stereotype.Repository;
|
|
||||||
|
|
||||||
@Repository
|
|
||||||
public class ParentDao extends AbstractHibernateDao<Parent> implements IParentDao {
|
|
||||||
|
|
||||||
public ParentDao() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
setClazz(Parent.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
}
|
|
@ -1,242 +0,0 @@
|
|||||||
package com.baeldung.persistence.model;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.Date;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import javax.persistence.CascadeType;
|
|
||||||
import javax.persistence.Column;
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.EntityListeners;
|
|
||||||
import javax.persistence.FetchType;
|
|
||||||
import javax.persistence.GeneratedValue;
|
|
||||||
import javax.persistence.GenerationType;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.NamedQuery;
|
|
||||||
import javax.persistence.OneToMany;
|
|
||||||
import javax.persistence.PrePersist;
|
|
||||||
import javax.persistence.PreRemove;
|
|
||||||
import javax.persistence.PreUpdate;
|
|
||||||
|
|
||||||
import org.hibernate.annotations.OrderBy;
|
|
||||||
import org.hibernate.envers.Audited;
|
|
||||||
import org.jboss.logging.Logger;
|
|
||||||
import org.springframework.data.annotation.CreatedBy;
|
|
||||||
import org.springframework.data.annotation.CreatedDate;
|
|
||||||
import org.springframework.data.annotation.LastModifiedBy;
|
|
||||||
import org.springframework.data.annotation.LastModifiedDate;
|
|
||||||
import org.springframework.data.jpa.domain.support.AuditingEntityListener;
|
|
||||||
|
|
||||||
import com.google.common.collect.Sets;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
@NamedQuery(name = "Bar.findAll", query = "SELECT b FROM Bar b")
|
|
||||||
@Audited
|
|
||||||
@EntityListeners(AuditingEntityListener.class)
|
|
||||||
public class Bar implements Serializable {
|
|
||||||
|
|
||||||
private static Logger logger = Logger.getLogger(Bar.class);
|
|
||||||
|
|
||||||
public enum OPERATION {
|
|
||||||
INSERT, UPDATE, DELETE;
|
|
||||||
private String value;
|
|
||||||
|
|
||||||
OPERATION() {
|
|
||||||
value = toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getValue() {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static OPERATION parse(final String value) {
|
|
||||||
OPERATION operation = null;
|
|
||||||
for (final OPERATION op : OPERATION.values()) {
|
|
||||||
if (op.getValue().equals(value)) {
|
|
||||||
operation = op;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return operation;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue(strategy = GenerationType.AUTO)
|
|
||||||
@Column(name = "id")
|
|
||||||
private int id;
|
|
||||||
|
|
||||||
@Column(name = "name")
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
@OneToMany(mappedBy = "bar", cascade = CascadeType.ALL, fetch = FetchType.LAZY)
|
|
||||||
@OrderBy(clause = "NAME DESC")
|
|
||||||
// @NotAudited
|
|
||||||
private Set<Foo> fooSet = Sets.newHashSet();
|
|
||||||
|
|
||||||
@Column(name = "operation")
|
|
||||||
private String operation;
|
|
||||||
|
|
||||||
@Column(name = "timestamp")
|
|
||||||
private long timestamp;
|
|
||||||
|
|
||||||
@Column(name = "created_date", updatable = false, nullable = false)
|
|
||||||
@CreatedDate
|
|
||||||
private long createdDate;
|
|
||||||
|
|
||||||
@Column(name = "modified_date")
|
|
||||||
@LastModifiedDate
|
|
||||||
private long modifiedDate;
|
|
||||||
|
|
||||||
@Column(name = "created_by")
|
|
||||||
@CreatedBy
|
|
||||||
private String createdBy;
|
|
||||||
|
|
||||||
@Column(name = "modified_by")
|
|
||||||
@LastModifiedBy
|
|
||||||
private String modifiedBy;
|
|
||||||
|
|
||||||
public Bar() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Bar(final String name) {
|
|
||||||
super();
|
|
||||||
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
public Set<Foo> getFooSet() {
|
|
||||||
return fooSet;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setFooSet(final Set<Foo> fooSet) {
|
|
||||||
this.fooSet = fooSet;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(final int id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(final String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public OPERATION getOperation() {
|
|
||||||
return OPERATION.parse(operation);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setOperation(final OPERATION operation) {
|
|
||||||
this.operation = operation.getValue();
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getTimestamp() {
|
|
||||||
return timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTimestamp(final long timestamp) {
|
|
||||||
this.timestamp = timestamp;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getCreatedDate() {
|
|
||||||
return createdDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreatedDate(final long createdDate) {
|
|
||||||
this.createdDate = createdDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getModifiedDate() {
|
|
||||||
return modifiedDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setModifiedDate(final long modifiedDate) {
|
|
||||||
this.modifiedDate = modifiedDate;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getCreatedBy() {
|
|
||||||
return createdBy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCreatedBy(final String createdBy) {
|
|
||||||
this.createdBy = createdBy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getModifiedBy() {
|
|
||||||
return modifiedBy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setModifiedBy(final String modifiedBy) {
|
|
||||||
this.modifiedBy = modifiedBy;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setOperation(final String operation) {
|
|
||||||
this.operation = operation;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int hashCode() {
|
|
||||||
final int prime = 31;
|
|
||||||
int result = 1;
|
|
||||||
result = prime * result + ((name == null) ? 0 : name.hashCode());
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean equals(final Object obj) {
|
|
||||||
if (this == obj)
|
|
||||||
return true;
|
|
||||||
if (obj == null)
|
|
||||||
return false;
|
|
||||||
if (getClass() != obj.getClass())
|
|
||||||
return false;
|
|
||||||
final Bar other = (Bar) obj;
|
|
||||||
if (name == null) {
|
|
||||||
if (other.name != null)
|
|
||||||
return false;
|
|
||||||
} else if (!name.equals(other.name))
|
|
||||||
return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
|
||||||
builder.append("Bar [name=").append(name).append("]");
|
|
||||||
return builder.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
@PrePersist
|
|
||||||
public void onPrePersist() {
|
|
||||||
logger.info("@PrePersist");
|
|
||||||
audit(OPERATION.INSERT);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PreUpdate
|
|
||||||
public void onPreUpdate() {
|
|
||||||
logger.info("@PreUpdate");
|
|
||||||
audit(OPERATION.UPDATE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@PreRemove
|
|
||||||
public void onPreRemove() {
|
|
||||||
logger.info("@PreRemove");
|
|
||||||
audit(OPERATION.DELETE);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void audit(final OPERATION operation) {
|
|
||||||
setOperation(operation);
|
|
||||||
setTimestamp((new Date()).getTime());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,51 +0,0 @@
|
|||||||
package com.baeldung.persistence.model;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.GeneratedValue;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.OneToOne;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
public class Child implements Serializable {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
@OneToOne(mappedBy = "child")
|
|
||||||
private Parent parent;
|
|
||||||
|
|
||||||
public Child() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(final long id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Parent getParent() {
|
|
||||||
return parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setParent(final Parent parent) {
|
|
||||||
this.parent = parent;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
|
||||||
builder.append("Child [id=").append(id).append("]");
|
|
||||||
return builder.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,25 +1,9 @@
|
|||||||
package com.baeldung.persistence.model;
|
package com.baeldung.persistence.model;
|
||||||
|
|
||||||
|
import javax.persistence.*;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
import javax.persistence.CascadeType;
|
|
||||||
import javax.persistence.Column;
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.FetchType;
|
|
||||||
import javax.persistence.GeneratedValue;
|
|
||||||
import javax.persistence.GenerationType;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.JoinColumn;
|
|
||||||
import javax.persistence.ManyToOne;
|
|
||||||
import javax.persistence.NamedNativeQueries;
|
|
||||||
import javax.persistence.NamedNativeQuery;
|
|
||||||
|
|
||||||
import org.hibernate.envers.Audited;
|
|
||||||
|
|
||||||
@NamedNativeQueries({ @NamedNativeQuery(name = "callGetAllFoos", query = "CALL GetAllFoos()", resultClass = Foo.class), @NamedNativeQuery(name = "callGetFoosByName", query = "CALL GetFoosByName(:fooName)", resultClass = Foo.class) })
|
|
||||||
@Entity
|
@Entity
|
||||||
@Audited
|
|
||||||
// @Proxy(lazy = false)
|
|
||||||
public class Foo implements Serializable {
|
public class Foo implements Serializable {
|
||||||
|
|
||||||
@Id
|
@Id
|
||||||
@ -30,10 +14,6 @@ public class Foo implements Serializable {
|
|||||||
@Column(name = "name")
|
@Column(name = "name")
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
@ManyToOne(targetEntity = Bar.class, cascade = CascadeType.ALL, fetch = FetchType.EAGER)
|
|
||||||
@JoinColumn(name = "BAR_ID")
|
|
||||||
private Bar bar = new Bar();
|
|
||||||
|
|
||||||
public Foo() {
|
public Foo() {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
@ -43,16 +23,6 @@ public class Foo implements Serializable {
|
|||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
public Bar getBar() {
|
|
||||||
return bar;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setBar(final Bar bar) {
|
|
||||||
this.bar = bar;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getId() {
|
public long getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
@ -69,8 +39,6 @@ public class Foo implements Serializable {
|
|||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
final int prime = 31;
|
final int prime = 31;
|
||||||
|
@ -1,60 +0,0 @@
|
|||||||
package com.baeldung.persistence.model;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
import javax.persistence.CascadeType;
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.GeneratedValue;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
import javax.persistence.JoinColumn;
|
|
||||||
import javax.persistence.OneToOne;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
public class Parent implements Serializable {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue
|
|
||||||
private long id;
|
|
||||||
|
|
||||||
@OneToOne(cascade = { CascadeType.PERSIST, CascadeType.MERGE, CascadeType.REFRESH, CascadeType.DETACH })
|
|
||||||
@JoinColumn(name = "child_fk")
|
|
||||||
private Child child;
|
|
||||||
|
|
||||||
public Parent() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Parent(final Child child) {
|
|
||||||
super();
|
|
||||||
|
|
||||||
this.child = child;
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(final long id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Child getChild() {
|
|
||||||
return child;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setChild(final Child child) {
|
|
||||||
this.child = child;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
final StringBuilder builder = new StringBuilder();
|
|
||||||
builder.append("Parent [id=").append(id).append("]");
|
|
||||||
return builder.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,31 +0,0 @@
|
|||||||
package com.baeldung.persistence.model;
|
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
|
||||||
import javax.persistence.GeneratedValue;
|
|
||||||
import javax.persistence.Id;
|
|
||||||
|
|
||||||
@Entity
|
|
||||||
public class Person {
|
|
||||||
|
|
||||||
@Id
|
|
||||||
@GeneratedValue
|
|
||||||
private Long id;
|
|
||||||
|
|
||||||
private 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;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
|
|
||||||
public interface IBarAuditableService extends IBarService, IAuditOperations<Bar> {
|
|
||||||
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
|
|
||||||
public interface IBarService extends IOperations<Bar> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Child;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
|
|
||||||
public interface IChildService extends IOperations<Child> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
|
|
||||||
public interface IFooAuditableService extends IFooService, IAuditOperations<Foo> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
|
|
||||||
public interface IFooService extends IOperations<Foo> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Parent;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
|
|
||||||
public interface IParentService extends IOperations<Parent> {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,30 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
@Transactional(value = "hibernateTransactionManager")
|
|
||||||
public abstract class AbstractHibernateAuditableService<T extends Serializable> extends AbstractHibernateService<T> implements IOperations<T>, IAuditOperations<T> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> getEntitiesAtRevision(final Number revision) {
|
|
||||||
return getAuditableDao().getEntitiesAtRevision(revision);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> getEntitiesModifiedAtRevision(final Number revision) {
|
|
||||||
return getAuditableDao().getEntitiesModifiedAtRevision(revision);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> getRevisions() {
|
|
||||||
return getAuditableDao().getRevisions();
|
|
||||||
}
|
|
||||||
|
|
||||||
abstract protected IAuditOperations<T> getAuditableDao();
|
|
||||||
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
@Transactional(value = "hibernateTransactionManager")
|
|
||||||
public abstract class AbstractHibernateService<T extends Serializable> extends AbstractService<T> implements IOperations<T> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T findOne(final long id) {
|
|
||||||
return super.findOne(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> findAll() {
|
|
||||||
return super.findAll();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void create(final T entity) {
|
|
||||||
super.create(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T update(final T entity) {
|
|
||||||
return super.update(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void delete(final T entity) {
|
|
||||||
super.delete(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteById(final long entityId) {
|
|
||||||
super.deleteById(entityId);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
@Transactional(value = "jpaTransactionManager")
|
|
||||||
public abstract class AbstractJpaService<T extends Serializable> extends AbstractService<T> implements IOperations<T> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T findOne(final long id) {
|
|
||||||
return super.findOne(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> findAll() {
|
|
||||||
return super.findAll();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void create(final T entity) {
|
|
||||||
super.create(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T update(final T entity) {
|
|
||||||
return super.update(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void delete(final T entity) {
|
|
||||||
super.delete(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteById(final long entityId) {
|
|
||||||
super.deleteById(entityId);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
|
|
||||||
public abstract class AbstractService<T extends Serializable> implements IOperations<T> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T findOne(final long id) {
|
|
||||||
return getDao().findOne(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> findAll() {
|
|
||||||
return getDao().findAll();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void create(final T entity) {
|
|
||||||
getDao().create(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T update(final T entity) {
|
|
||||||
return getDao().update(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void delete(final T entity) {
|
|
||||||
getDao().delete(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteById(final long entityId) {
|
|
||||||
getDao().deleteById(entityId);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract IOperations<T> getDao();
|
|
||||||
|
|
||||||
}
|
|
@ -1,46 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.common;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import org.springframework.data.repository.CrudRepository;
|
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
|
||||||
|
|
||||||
@Transactional(value = "jpaTransactionManager")
|
|
||||||
public abstract class AbstractSpringDataJpaService<T extends Serializable> implements IOperations<T> {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T findOne(final long id) {
|
|
||||||
return getDao().findOne(Long.valueOf(id));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<T> findAll() {
|
|
||||||
return Lists.newArrayList(getDao().findAll());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void create(final T entity) {
|
|
||||||
getDao().save(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public T update(final T entity) {
|
|
||||||
return getDao().save(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void delete(final T entity) {
|
|
||||||
getDao().delete(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void deleteById(final long entityId) {
|
|
||||||
getDao().delete(Long.valueOf(entityId));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected abstract CrudRepository<T, Serializable> getDao();
|
|
||||||
}
|
|
@ -1,41 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractHibernateAuditableService;
|
|
||||||
import com.baeldung.persistence.dao.IBarAuditableDao;
|
|
||||||
import com.baeldung.persistence.dao.IBarDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.service.IBarAuditableService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class BarAuditableService extends AbstractHibernateAuditableService<Bar> implements IBarAuditableService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barHibernateDao")
|
|
||||||
private IBarDao dao;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barHibernateAuditableDao")
|
|
||||||
private IBarAuditableDao auditDao;
|
|
||||||
|
|
||||||
public BarAuditableService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Bar> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IAuditOperations<Bar> getAuditableDao() {
|
|
||||||
return auditDao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,30 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IBarDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.service.IBarService;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractJpaService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class BarJpaService extends AbstractJpaService<Bar> implements IBarService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barJpaDao")
|
|
||||||
private IBarDao dao;
|
|
||||||
|
|
||||||
public BarJpaService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Bar> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,30 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IBarDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.service.IBarService;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractHibernateService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class BarService extends AbstractHibernateService<Bar> implements IBarService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barHibernateDao")
|
|
||||||
private IBarDao dao;
|
|
||||||
|
|
||||||
public BarService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Bar> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import java.io.Serializable;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.service.common.AbstractSpringDataJpaService;
|
|
||||||
import com.baeldung.persistence.dao.IBarCrudRepository;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.service.IBarService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.data.repository.CrudRepository;
|
|
||||||
|
|
||||||
public class BarSpringDataJpaService extends AbstractSpringDataJpaService<Bar> implements IBarService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IBarCrudRepository dao;
|
|
||||||
|
|
||||||
public BarSpringDataJpaService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected CrudRepository<Bar, Serializable> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Child;
|
|
||||||
import com.baeldung.persistence.service.IChildService;
|
|
||||||
import com.baeldung.persistence.dao.IChildDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractHibernateService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class ChildService extends AbstractHibernateService<Child> implements IChildService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IChildDao dao;
|
|
||||||
|
|
||||||
public ChildService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Child> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,41 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.common.IAuditOperations;
|
|
||||||
import com.baeldung.persistence.service.IFooAuditableService;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractHibernateAuditableService;
|
|
||||||
import com.baeldung.persistence.dao.IFooAuditableDao;
|
|
||||||
import com.baeldung.persistence.dao.IFooDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class FooAuditableService extends AbstractHibernateAuditableService<Foo> implements IFooAuditableService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("fooHibernateDao")
|
|
||||||
private IFooDao dao;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("fooHibernateAuditableDao")
|
|
||||||
private IFooAuditableDao auditDao;
|
|
||||||
|
|
||||||
public FooAuditableService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Foo> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IAuditOperations<Foo> getAuditableDao() {
|
|
||||||
return auditDao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,30 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IFooDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.persistence.service.IFooService;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractHibernateService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class FooService extends AbstractHibernateService<Foo> implements IFooService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("fooHibernateDao")
|
|
||||||
private IFooDao dao;
|
|
||||||
|
|
||||||
public FooService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Foo> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
package com.baeldung.persistence.service.impl;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Parent;
|
|
||||||
import com.baeldung.persistence.service.IParentService;
|
|
||||||
import com.baeldung.persistence.dao.IParentDao;
|
|
||||||
import com.baeldung.persistence.dao.common.IOperations;
|
|
||||||
import com.baeldung.persistence.service.common.AbstractHibernateService;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.stereotype.Service;
|
|
||||||
|
|
||||||
@Service
|
|
||||||
public class ParentService extends AbstractHibernateService<Parent> implements IParentService {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IParentDao dao;
|
|
||||||
|
|
||||||
public ParentService() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected IOperations<Parent> getDao() {
|
|
||||||
return dao;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,9 +1,8 @@
|
|||||||
package com.baeldung.spring;
|
package com.baeldung.spring;
|
||||||
|
|
||||||
import java.util.Properties;
|
import com.baeldung.persistence.dao.IFooDao;
|
||||||
|
import com.baeldung.persistence.dao.impl.FooHibernateDao;
|
||||||
import javax.sql.DataSource;
|
import com.google.common.base.Preconditions;
|
||||||
|
|
||||||
import org.apache.tomcat.dbcp.dbcp2.BasicDataSource;
|
import org.apache.tomcat.dbcp.dbcp2.BasicDataSource;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
@ -12,42 +11,17 @@ import org.springframework.context.annotation.Configuration;
|
|||||||
import org.springframework.context.annotation.PropertySource;
|
import org.springframework.context.annotation.PropertySource;
|
||||||
import org.springframework.core.env.Environment;
|
import org.springframework.core.env.Environment;
|
||||||
import org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor;
|
import org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor;
|
||||||
import org.springframework.data.jpa.repository.config.EnableJpaAuditing;
|
|
||||||
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
|
||||||
import org.springframework.orm.hibernate5.HibernateTransactionManager;
|
import org.springframework.orm.hibernate5.HibernateTransactionManager;
|
||||||
import org.springframework.orm.hibernate5.LocalSessionFactoryBean;
|
import org.springframework.orm.hibernate5.LocalSessionFactoryBean;
|
||||||
import org.springframework.orm.jpa.JpaTransactionManager;
|
|
||||||
import org.springframework.orm.jpa.JpaVendorAdapter;
|
|
||||||
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
|
|
||||||
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
|
|
||||||
import org.springframework.transaction.PlatformTransactionManager;
|
import org.springframework.transaction.PlatformTransactionManager;
|
||||||
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
|
|
||||||
import com.baeldung.persistence.dao.IBarAuditableDao;
|
import javax.sql.DataSource;
|
||||||
import com.baeldung.persistence.dao.IBarDao;
|
import java.util.Properties;
|
||||||
import com.baeldung.persistence.dao.IFooAuditableDao;
|
|
||||||
import com.baeldung.persistence.dao.IFooDao;
|
|
||||||
import com.baeldung.persistence.dao.impl.BarAuditableDao;
|
|
||||||
import com.baeldung.persistence.dao.impl.BarDao;
|
|
||||||
import com.baeldung.persistence.dao.impl.BarJpaDao;
|
|
||||||
import com.baeldung.persistence.dao.impl.FooAuditableDao;
|
|
||||||
import com.baeldung.persistence.dao.impl.FooDao;
|
|
||||||
import com.baeldung.persistence.service.IBarAuditableService;
|
|
||||||
import com.baeldung.persistence.service.IBarService;
|
|
||||||
import com.baeldung.persistence.service.IFooAuditableService;
|
|
||||||
import com.baeldung.persistence.service.IFooService;
|
|
||||||
import com.baeldung.persistence.service.impl.BarAuditableService;
|
|
||||||
import com.baeldung.persistence.service.impl.BarJpaService;
|
|
||||||
import com.baeldung.persistence.service.impl.BarSpringDataJpaService;
|
|
||||||
import com.baeldung.persistence.service.impl.FooAuditableService;
|
|
||||||
import com.baeldung.persistence.service.impl.FooService;
|
|
||||||
import com.google.common.base.Preconditions;
|
|
||||||
|
|
||||||
@Configuration
|
@Configuration
|
||||||
@EnableTransactionManagement
|
@EnableTransactionManagement
|
||||||
@EnableJpaRepositories(basePackages = { "com.baeldung.persistence" }, transactionManagerRef = "jpaTransactionManager")
|
@PropertySource({ "classpath:persistence-h2.properties" })
|
||||||
@EnableJpaAuditing
|
|
||||||
@PropertySource({ "classpath:persistence-mysql.properties" })
|
|
||||||
@ComponentScan({ "com.baeldung.persistence" })
|
@ComponentScan({ "com.baeldung.persistence" })
|
||||||
public class PersistenceConfig {
|
public class PersistenceConfig {
|
||||||
|
|
||||||
@ -57,7 +31,7 @@ public class PersistenceConfig {
|
|||||||
@Bean
|
@Bean
|
||||||
public LocalSessionFactoryBean sessionFactory() {
|
public LocalSessionFactoryBean sessionFactory() {
|
||||||
final LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
|
final LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
|
||||||
sessionFactory.setDataSource(restDataSource());
|
sessionFactory.setDataSource(dataSource());
|
||||||
sessionFactory.setPackagesToScan(new String[] { "com.baeldung.persistence.model" });
|
sessionFactory.setPackagesToScan(new String[] { "com.baeldung.persistence.model" });
|
||||||
sessionFactory.setHibernateProperties(hibernateProperties());
|
sessionFactory.setHibernateProperties(hibernateProperties());
|
||||||
|
|
||||||
@ -65,20 +39,7 @@ public class PersistenceConfig {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
|
public DataSource dataSource() {
|
||||||
final LocalContainerEntityManagerFactoryBean emf = new LocalContainerEntityManagerFactoryBean();
|
|
||||||
emf.setDataSource(restDataSource());
|
|
||||||
emf.setPackagesToScan(new String[] { "com.baeldung.persistence.model" });
|
|
||||||
|
|
||||||
final JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
|
|
||||||
emf.setJpaVendorAdapter(vendorAdapter);
|
|
||||||
emf.setJpaProperties(hibernateProperties());
|
|
||||||
|
|
||||||
return emf;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public DataSource restDataSource() {
|
|
||||||
final BasicDataSource dataSource = new BasicDataSource();
|
final BasicDataSource dataSource = new BasicDataSource();
|
||||||
dataSource.setDriverClassName(Preconditions.checkNotNull(env.getProperty("jdbc.driverClassName")));
|
dataSource.setDriverClassName(Preconditions.checkNotNull(env.getProperty("jdbc.driverClassName")));
|
||||||
dataSource.setUrl(Preconditions.checkNotNull(env.getProperty("jdbc.url")));
|
dataSource.setUrl(Preconditions.checkNotNull(env.getProperty("jdbc.url")));
|
||||||
@ -95,66 +56,14 @@ public class PersistenceConfig {
|
|||||||
return transactionManager;
|
return transactionManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
|
||||||
public PlatformTransactionManager jpaTransactionManager() {
|
|
||||||
final JpaTransactionManager transactionManager = new JpaTransactionManager();
|
|
||||||
transactionManager.setEntityManagerFactory(entityManagerFactory().getObject());
|
|
||||||
return transactionManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public PersistenceExceptionTranslationPostProcessor exceptionTranslation() {
|
public PersistenceExceptionTranslationPostProcessor exceptionTranslation() {
|
||||||
return new PersistenceExceptionTranslationPostProcessor();
|
return new PersistenceExceptionTranslationPostProcessor();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IBarService barJpaService() {
|
|
||||||
return new BarJpaService();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IBarService barSpringDataJpaService() {
|
|
||||||
return new BarSpringDataJpaService();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IFooService fooHibernateService() {
|
|
||||||
return new FooService();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IBarAuditableService barHibernateAuditableService() {
|
|
||||||
return new BarAuditableService();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IFooAuditableService fooHibernateAuditableService() {
|
|
||||||
return new FooAuditableService();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IBarDao barJpaDao() {
|
|
||||||
return new BarJpaDao();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IBarDao barHibernateDao() {
|
|
||||||
return new BarDao();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IBarAuditableDao barHibernateAuditableDao() {
|
|
||||||
return new BarAuditableDao();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public IFooDao fooHibernateDao() {
|
public IFooDao fooHibernateDao() {
|
||||||
return new FooDao();
|
return new FooHibernateDao();
|
||||||
}
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
public IFooAuditableDao fooHibernateAuditableDao() {
|
|
||||||
return new FooAuditableDao();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private final Properties hibernateProperties() {
|
private final Properties hibernateProperties() {
|
||||||
|
@ -1,17 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!DOCTYPE hibernate-configuration PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
|
|
||||||
|
|
||||||
|
|
||||||
<hibernate-configuration>
|
|
||||||
<session-factory>
|
|
||||||
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
|
|
||||||
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
|
|
||||||
<property name="hibernate.connection.username">root</property>
|
|
||||||
<property name="hibernate.connection.password">root</property>
|
|
||||||
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
|
|
||||||
<property name="show_sql">true</property>
|
|
||||||
<mapping resource="com/baeldung/hibernate/criteria/model/Item.hbm.xml" />
|
|
||||||
</session-factory>
|
|
||||||
</hibernate-configuration>
|
|
@ -1,7 +0,0 @@
|
|||||||
CREATE TABLE `item` (
|
|
||||||
`ITEM_ID` int(11) NOT NULL AUTO_INCREMENT,
|
|
||||||
`ITEM_DESC` varchar(100) DEFAULT NULL,
|
|
||||||
`ITEM_PRICE` int(11) NOT NULL,
|
|
||||||
`ITEM_NAME` varchar(255) NOT NULL,
|
|
||||||
PRIMARY KEY (`ITEM_ID`)
|
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=latin1;
|
|
@ -1,20 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!DOCTYPE hibernate-configuration PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
|
|
||||||
|
|
||||||
<hibernate-configuration>
|
|
||||||
<session-factory>
|
|
||||||
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
|
|
||||||
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
|
|
||||||
<property name="hibernate.connection.username">root</property>
|
|
||||||
<property name="hibernate.connection.password">root</property>
|
|
||||||
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
|
|
||||||
<property name="show_sql">true</property>
|
|
||||||
<property name="hbm2ddl.auto">validate</property>
|
|
||||||
|
|
||||||
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.UserEager" />
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.OrderDetailEager" />
|
|
||||||
</session-factory>
|
|
||||||
</hibernate-configuration>
|
|
@ -1,17 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!DOCTYPE hibernate-configuration PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
|
|
||||||
|
|
||||||
<hibernate-configuration>
|
|
||||||
<session-factory>
|
|
||||||
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
|
|
||||||
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
|
|
||||||
<property name="hibernate.connection.username">root</property>
|
|
||||||
<property name="hibernate.connection.password">root</property>
|
|
||||||
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
|
|
||||||
<property name="show_sql">true</property>
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.UserLazy" />
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.OrderDetail" />
|
|
||||||
</session-factory>
|
|
||||||
</hibernate-configuration>
|
|
@ -1,14 +0,0 @@
|
|||||||
CREATE TABLE `user` (
|
|
||||||
`user_id` int(10) NOT NULL AUTO_INCREMENT,
|
|
||||||
PRIMARY KEY (`user_id`)
|
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=latin1 ;
|
|
||||||
|
|
||||||
|
|
||||||
CREATE TABLE `user_order` (
|
|
||||||
`ORDER_ID` int(10) NOT NULL AUTO_INCREMENT,
|
|
||||||
`USER_ID` int(10) NOT NULL DEFAULT '0',
|
|
||||||
PRIMARY KEY (`ORDER_ID`,`USER_ID`),
|
|
||||||
KEY `USER_ID` (`USER_ID`),
|
|
||||||
CONSTRAINT `user_order_ibfk_1` FOREIGN KEY (`USER_ID`) REFERENCES `USER` (`user_id`)
|
|
||||||
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=latin1;
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
|||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(1,'item One', 'test 1', 35.12);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(2,'Pogo stick', 'Pogo stick', 466.12);
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(3,'Raft', 'Raft', 345.12);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(4,'Skate Board', 'Skating', 135.71);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(5,'Umbrella', 'Umbrella for Rain', 619.25);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(6,'Glue', 'Glue for home', 432.73);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(7,'Paint', 'Paint for Room', 1311.40);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(8,'Red paint', 'Red paint for room', 1135.71);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(9,'Household Chairs', 'Chairs for house', 25.71);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(10,'Office Chairs', 'Chairs for office', 395.98);
|
|
||||||
|
|
||||||
insert into item (item_id, item_name, item_desc, item_price)
|
|
||||||
values(11,'Outdoor Chairs', 'Chairs for outdoor activities', 1234.36);
|
|
@ -0,0 +1,13 @@
|
|||||||
|
# jdbc.X
|
||||||
|
jdbc.driverClassName=org.h2.Driver
|
||||||
|
jdbc.url=jdbc:h2:mem:db;DB_CLOSE_DELAY=-1
|
||||||
|
jdbc.user=sa
|
||||||
|
jdbc.pass=sa
|
||||||
|
|
||||||
|
# hibernate.X
|
||||||
|
hibernate.dialect=org.hibernate.dialect.H2Dialect
|
||||||
|
hibernate.show_sql=false
|
||||||
|
hibernate.hbm2ddl.auto=create-drop
|
||||||
|
|
||||||
|
# envers.X
|
||||||
|
envers.audit_table_suffix=_audit_log
|
@ -1,20 +0,0 @@
|
|||||||
DELIMITER //
|
|
||||||
CREATE PROCEDURE GetFoosByName(IN fooName VARCHAR(255))
|
|
||||||
LANGUAGE SQL
|
|
||||||
DETERMINISTIC
|
|
||||||
SQL SECURITY DEFINER
|
|
||||||
BEGIN
|
|
||||||
SELECT * FROM foo WHERE name = fooName;
|
|
||||||
END //
|
|
||||||
DELIMITER ;
|
|
||||||
|
|
||||||
|
|
||||||
DELIMITER //
|
|
||||||
CREATE PROCEDURE GetAllFoos()
|
|
||||||
LANGUAGE SQL
|
|
||||||
DETERMINISTIC
|
|
||||||
SQL SECURITY DEFINER
|
|
||||||
BEGIN
|
|
||||||
SELECT * FROM foo;
|
|
||||||
END //
|
|
||||||
DELIMITER ;
|
|
@ -1,37 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<beans:beans xmlns="http://www.springframework.org/schema/security" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:beans="http://www.springframework.org/schema/beans"
|
|
||||||
xsi:schemaLocation="
|
|
||||||
http://www.springframework.org/schema/security http://www.springframework.org/schema/security/spring-security-4.2.xsd
|
|
||||||
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd"
|
|
||||||
>
|
|
||||||
|
|
||||||
<http use-expressions="true">
|
|
||||||
<access-denied-handler error-page="/access-denied.html"/>
|
|
||||||
<intercept-url pattern="/access-denied*" access="hasAnyRole('ROLE_LOCATION_WRITE','ROLE_POLYGON_WRITE')"/>
|
|
||||||
<intercept-url pattern="/admin/**" access="hasAnyRole('ROLE_ADMIN')"/>
|
|
||||||
<intercept-url pattern="/organization/**" access="hasAnyRole('ROLE_ORGANIZATION')"/>
|
|
||||||
<intercept-url pattern="/location/edit*" access="hasAnyRole('ROLE_LOCATION_WRITE')"/>
|
|
||||||
<intercept-url pattern="/location/view*" access="permitAll"/>
|
|
||||||
|
|
||||||
<intercept-url pattern="/login*" access="isAnonymous()"/>
|
|
||||||
<intercept-url pattern="/register*" access="isAnonymous()"/>
|
|
||||||
<intercept-url pattern="/login-denied/**" access="isAnonymous()"/>
|
|
||||||
|
|
||||||
<intercept-url pattern="/**" access="permitAll"/>
|
|
||||||
|
|
||||||
<form-login login-page='/login.html' default-target-url="/" always-use-default-target="false" authentication-failure-url="/login.html?error=true"/>
|
|
||||||
|
|
||||||
<logout/>
|
|
||||||
|
|
||||||
<anonymous/>
|
|
||||||
|
|
||||||
<session-management invalid-session-url="/">
|
|
||||||
<concurrency-control max-sessions="1"/>
|
|
||||||
</session-management>
|
|
||||||
</http>
|
|
||||||
|
|
||||||
<authentication-manager alias="authenticationManager" erase-credentials="false">
|
|
||||||
<authentication-provider ref="restAuthenticationProvider"/>
|
|
||||||
</authentication-manager>
|
|
||||||
|
|
||||||
</beans:beans>
|
|
@ -1,183 +0,0 @@
|
|||||||
package com.baeldung.hibernate.criteria;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertArrayEquals;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import com.baeldung.hibernate.criteria.model.Item;
|
|
||||||
import com.baeldung.hibernate.criteria.util.HibernateUtil;
|
|
||||||
import com.baeldung.hibernate.criteria.view.ApplicationView;
|
|
||||||
|
|
||||||
public class HibernateCriteriaIntegrationTest {
|
|
||||||
|
|
||||||
final private ApplicationView av = new ApplicationView();
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testPerformanceOfCriteria() {
|
|
||||||
assertTrue(av.checkIfCriteriaTimeLower());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testLikeCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedLikeList = session.createQuery("From Item where itemName like '%chair%'").getResultList();
|
|
||||||
final String expectedLikeItems[] = new String[expectedLikeList.size()];
|
|
||||||
for (int i = 0; i < expectedLikeList.size(); i++) {
|
|
||||||
expectedLikeItems[i] = expectedLikeList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedLikeItems, av.likeCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testILikeCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedChairCaseList = session.createQuery("From Item where itemName like '%Chair%'").getResultList();
|
|
||||||
final String expectedChairCaseItems[] = new String[expectedChairCaseList.size()];
|
|
||||||
for (int i = 0; i < expectedChairCaseList.size(); i++) {
|
|
||||||
expectedChairCaseItems[i] = expectedChairCaseList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedChairCaseItems, av.likeCaseCriteria());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testNullCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedIsNullDescItemsList = session.createQuery("From Item where itemDescription is null").getResultList();
|
|
||||||
final String expectedIsNullDescItems[] = new String[expectedIsNullDescItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedIsNullDescItemsList.size(); i++) {
|
|
||||||
expectedIsNullDescItems[i] = expectedIsNullDescItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedIsNullDescItems, av.nullCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testIsNotNullCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedIsNotNullDescItemsList = session.createQuery("From Item where itemDescription is not null").getResultList();
|
|
||||||
final String expectedIsNotNullDescItems[] = new String[expectedIsNotNullDescItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedIsNotNullDescItemsList.size(); i++) {
|
|
||||||
expectedIsNotNullDescItems[i] = expectedIsNotNullDescItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedIsNotNullDescItems, av.notNullCriteria());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testAverageProjection() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Double> expectedAvgProjItemsList = session.createQuery("Select avg(itemPrice) from Item item").getResultList();
|
|
||||||
|
|
||||||
final Double expectedAvgProjItems[] = new Double[expectedAvgProjItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedAvgProjItemsList.size(); i++) {
|
|
||||||
expectedAvgProjItems[i] = expectedAvgProjItemsList.get(i);
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedAvgProjItems, av.projectionAverage());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testRowCountProjection() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Long> expectedCountProjItemsList = session.createQuery("Select count(*) from Item").getResultList();
|
|
||||||
final Long expectedCountProjItems[] = new Long[expectedCountProjItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedCountProjItemsList.size(); i++) {
|
|
||||||
expectedCountProjItems[i] = expectedCountProjItemsList.get(i);
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedCountProjItems, av.projectionRowCount());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testOrCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedOrCritItemsList = session.createQuery("From Item where itemPrice>1000 or itemName like 'Chair%'").getResultList();
|
|
||||||
final String expectedOrCritItems[] = new String[expectedOrCritItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedOrCritItemsList.size(); i++) {
|
|
||||||
expectedOrCritItems[i] = expectedOrCritItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedOrCritItems, av.orLogicalCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testAndCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedAndCritItemsList = session.createQuery("From Item where itemPrice>1000 and itemName like 'Chair%'").getResultList();
|
|
||||||
final String expectedAndCritItems[] = new String[expectedAndCritItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedAndCritItemsList.size(); i++) {
|
|
||||||
expectedAndCritItems[i] = expectedAndCritItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedAndCritItems, av.andLogicalCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testMultiCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedMultiCritItemsList = session.createQuery("From Item where itemDescription is null and itemName like'chair%'").getResultList();
|
|
||||||
final String expectedMultiCritItems[] = new String[expectedMultiCritItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedMultiCritItemsList.size(); i++) {
|
|
||||||
expectedMultiCritItems[i] = expectedMultiCritItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedMultiCritItems, av.twoCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testSortCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedSortCritItemsList = session.createQuery("From Item order by itemName asc, itemPrice desc").getResultList();
|
|
||||||
final String expectedSortCritItems[] = new String[expectedSortCritItemsList.size()];
|
|
||||||
for (int i = 0; i < expectedSortCritItemsList.size(); i++) {
|
|
||||||
expectedSortCritItems[i] = expectedSortCritItemsList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedSortCritItems, av.sortingCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testGreaterThanCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedGreaterThanList = session.createQuery("From Item where itemPrice>1000").getResultList();
|
|
||||||
final String expectedGreaterThanItems[] = new String[expectedGreaterThanList.size()];
|
|
||||||
for (int i = 0; i < expectedGreaterThanList.size(); i++) {
|
|
||||||
expectedGreaterThanItems[i] = expectedGreaterThanList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedGreaterThanItems, av.greaterThanCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testLessThanCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedLessList = session.createQuery("From Item where itemPrice<1000").getResultList();
|
|
||||||
final String expectedLessThanItems[] = new String[expectedLessList.size()];
|
|
||||||
for (int i = 0; i < expectedLessList.size(); i++) {
|
|
||||||
expectedLessThanItems[i] = expectedLessList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedLessThanItems, av.lessThanCriteria());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void betweenCriteriaQuery() {
|
|
||||||
final Session session = HibernateUtil.getHibernateSession();
|
|
||||||
final List<Item> expectedBetweenList = session.createQuery("From Item where itemPrice between 100 and 200").getResultList();
|
|
||||||
final String expectedPriceBetweenItems[] = new String[expectedBetweenList.size()];
|
|
||||||
for (int i = 0; i < expectedBetweenList.size(); i++) {
|
|
||||||
expectedPriceBetweenItems[i] = expectedBetweenList.get(i).getItemName();
|
|
||||||
}
|
|
||||||
session.close();
|
|
||||||
assertArrayEquals(expectedPriceBetweenItems, av.betweenCriteria());
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,42 +0,0 @@
|
|||||||
package com.baeldung.hibernate.fetching;
|
|
||||||
|
|
||||||
import com.baeldung.hibernate.fetching.model.OrderDetail;
|
|
||||||
import com.baeldung.hibernate.fetching.view.FetchingAppView;
|
|
||||||
import org.hibernate.Hibernate;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
public class HibernateFetchingIntegrationTest {
|
|
||||||
|
|
||||||
// this loads sample data in the database
|
|
||||||
@Before
|
|
||||||
public void addFecthingTestData() {
|
|
||||||
FetchingAppView fav = new FetchingAppView();
|
|
||||||
fav.createTestData();
|
|
||||||
}
|
|
||||||
|
|
||||||
// testLazyFetching() tests the lazy loading
|
|
||||||
// Since it lazily loaded so orderDetalSetLazy won't
|
|
||||||
// be initialized
|
|
||||||
@Test
|
|
||||||
public void testLazyFetching() {
|
|
||||||
FetchingAppView fav = new FetchingAppView();
|
|
||||||
Set<OrderDetail> orderDetalSetLazy = fav.lazyLoaded();
|
|
||||||
assertFalse(Hibernate.isInitialized(orderDetalSetLazy));
|
|
||||||
}
|
|
||||||
|
|
||||||
// testEagerFetching() tests the eager loading
|
|
||||||
// Since it eagerly loaded so orderDetalSetLazy would
|
|
||||||
// be initialized
|
|
||||||
@Test
|
|
||||||
public void testEagerFetching() {
|
|
||||||
FetchingAppView fav = new FetchingAppView();
|
|
||||||
Set<OrderDetail> orderDetalSetEager = fav.eagerLoaded();
|
|
||||||
assertTrue(Hibernate.isInitialized(orderDetalSetEager));
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
package com.baeldung.persistence;
|
|
||||||
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.junit.runners.Suite;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.audit.AuditTestSuite;
|
|
||||||
import com.baeldung.persistence.hibernate.FooPaginationPersistenceIntegrationTest;
|
|
||||||
import com.baeldung.persistence.hibernate.FooSortingPersistenceIntegrationTest;
|
|
||||||
import com.baeldung.persistence.service.FooServiceBasicPersistenceIntegrationTest;
|
|
||||||
import com.baeldung.persistence.service.FooServicePersistenceIntegrationTest;
|
|
||||||
import com.baeldung.persistence.service.ParentServicePersistenceIntegrationTest;
|
|
||||||
|
|
||||||
@RunWith(Suite.class)
|
|
||||||
@Suite.SuiteClasses({ // @formatter:off
|
|
||||||
AuditTestSuite.class
|
|
||||||
,FooServiceBasicPersistenceIntegrationTest.class
|
|
||||||
,FooPaginationPersistenceIntegrationTest.class
|
|
||||||
,FooServicePersistenceIntegrationTest.class
|
|
||||||
,ParentServicePersistenceIntegrationTest.class
|
|
||||||
,FooSortingPersistenceIntegrationTest.class
|
|
||||||
|
|
||||||
}) // @formatter:on
|
|
||||||
public class IntegrationTestSuite {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,14 +0,0 @@
|
|||||||
package com.baeldung.persistence.audit;
|
|
||||||
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.junit.runners.Suite;
|
|
||||||
|
|
||||||
@RunWith(Suite.class)
|
|
||||||
@Suite.SuiteClasses({ // @formatter:off
|
|
||||||
EnversFooBarAuditIntegrationTest.class,
|
|
||||||
JPABarAuditIntegrationTest.class,
|
|
||||||
SpringDataJPABarAuditIntegrationTest.class
|
|
||||||
}) // @formatter:on
|
|
||||||
public class AuditTestSuite {
|
|
||||||
//
|
|
||||||
}
|
|
@ -1,142 +0,0 @@
|
|||||||
package com.baeldung.persistence.audit;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.persistence.service.IBarAuditableService;
|
|
||||||
import com.baeldung.persistence.service.IFooAuditableService;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.AfterClass;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.BeforeClass;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class EnversFooBarAuditIntegrationTest {
|
|
||||||
|
|
||||||
private static Logger logger = LoggerFactory.getLogger(EnversFooBarAuditIntegrationTest.class);
|
|
||||||
|
|
||||||
@BeforeClass
|
|
||||||
public static void setUpBeforeClass() throws Exception {
|
|
||||||
logger.info("setUpBeforeClass()");
|
|
||||||
}
|
|
||||||
|
|
||||||
@AfterClass
|
|
||||||
public static void tearDownAfterClass() throws Exception {
|
|
||||||
logger.info("tearDownAfterClass()");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("fooHibernateAuditableService")
|
|
||||||
private IFooAuditableService fooService;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barHibernateAuditableService")
|
|
||||||
private IBarAuditableService barService;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private SessionFactory sessionFactory;
|
|
||||||
|
|
||||||
private Session session;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() throws Exception {
|
|
||||||
logger.info("setUp()");
|
|
||||||
makeRevisions();
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void tearDown() throws Exception {
|
|
||||||
logger.info("tearDown()");
|
|
||||||
session.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void makeRevisions() {
|
|
||||||
final Bar bar = rev1();
|
|
||||||
rev2(bar);
|
|
||||||
rev3(bar);
|
|
||||||
rev4(bar);
|
|
||||||
}
|
|
||||||
|
|
||||||
// REV #1: insert BAR & FOO1
|
|
||||||
private Bar rev1() {
|
|
||||||
final Bar bar = new Bar("BAR");
|
|
||||||
final Foo foo1 = new Foo("FOO1");
|
|
||||||
foo1.setBar(bar);
|
|
||||||
fooService.create(foo1);
|
|
||||||
return bar;
|
|
||||||
}
|
|
||||||
|
|
||||||
// REV #2: insert FOO2 & update BAR
|
|
||||||
private void rev2(final Bar bar) {
|
|
||||||
final Foo foo2 = new Foo("FOO2");
|
|
||||||
foo2.setBar(bar);
|
|
||||||
fooService.create(foo2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// REV #3: update BAR
|
|
||||||
private void rev3(final Bar bar) {
|
|
||||||
|
|
||||||
bar.setName("BAR1");
|
|
||||||
barService.update(bar);
|
|
||||||
}
|
|
||||||
|
|
||||||
// REV #4: insert FOO3 & update BAR
|
|
||||||
private void rev4(final Bar bar) {
|
|
||||||
|
|
||||||
final Foo foo3 = new Foo("FOO3");
|
|
||||||
foo3.setBar(bar);
|
|
||||||
fooService.create(foo3);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenFooBarsModified_thenFooBarsAudited() {
|
|
||||||
|
|
||||||
List<Bar> barRevisionList;
|
|
||||||
List<Foo> fooRevisionList;
|
|
||||||
|
|
||||||
// test Bar revisions
|
|
||||||
|
|
||||||
barRevisionList = barService.getRevisions();
|
|
||||||
|
|
||||||
assertNotNull(barRevisionList);
|
|
||||||
assertEquals(4, barRevisionList.size());
|
|
||||||
|
|
||||||
assertEquals("BAR", barRevisionList.get(0).getName());
|
|
||||||
assertEquals("BAR", barRevisionList.get(1).getName());
|
|
||||||
assertEquals("BAR1", barRevisionList.get(2).getName());
|
|
||||||
assertEquals("BAR1", barRevisionList.get(3).getName());
|
|
||||||
|
|
||||||
assertEquals(1, barRevisionList.get(0).getFooSet().size());
|
|
||||||
assertEquals(2, barRevisionList.get(1).getFooSet().size());
|
|
||||||
assertEquals(2, barRevisionList.get(2).getFooSet().size());
|
|
||||||
assertEquals(3, barRevisionList.get(3).getFooSet().size());
|
|
||||||
|
|
||||||
// test Foo revisions
|
|
||||||
|
|
||||||
fooRevisionList = fooService.getRevisions();
|
|
||||||
assertNotNull(fooRevisionList);
|
|
||||||
assertEquals(3, fooRevisionList.size());
|
|
||||||
assertEquals("FOO1", fooRevisionList.get(0).getName());
|
|
||||||
assertEquals("FOO2", fooRevisionList.get(1).getName());
|
|
||||||
assertEquals("FOO3", fooRevisionList.get(2).getName());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,102 +0,0 @@
|
|||||||
package com.baeldung.persistence.audit;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
|
||||||
import javax.persistence.EntityManagerFactory;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.model.Bar.OPERATION;
|
|
||||||
import com.baeldung.persistence.service.IBarService;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.AfterClass;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.BeforeClass;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class JPABarAuditIntegrationTest {
|
|
||||||
|
|
||||||
private static Logger logger = LoggerFactory.getLogger(JPABarAuditIntegrationTest.class);
|
|
||||||
|
|
||||||
@BeforeClass
|
|
||||||
public static void setUpBeforeClass() throws Exception {
|
|
||||||
logger.info("setUpBeforeClass()");
|
|
||||||
}
|
|
||||||
|
|
||||||
@AfterClass
|
|
||||||
public static void tearDownAfterClass() throws Exception {
|
|
||||||
logger.info("tearDownAfterClass()");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barJpaService")
|
|
||||||
private IBarService barService;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private EntityManagerFactory entityManagerFactory;
|
|
||||||
|
|
||||||
private EntityManager em;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() throws Exception {
|
|
||||||
logger.info("setUp()");
|
|
||||||
em = entityManagerFactory.createEntityManager();
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void tearDown() throws Exception {
|
|
||||||
logger.info("tearDown()");
|
|
||||||
em.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenBarsModified_thenBarsAudited() {
|
|
||||||
|
|
||||||
// insert BAR1
|
|
||||||
Bar bar1 = new Bar("BAR1");
|
|
||||||
barService.create(bar1);
|
|
||||||
|
|
||||||
// update BAR1
|
|
||||||
bar1.setName("BAR1a");
|
|
||||||
barService.update(bar1);
|
|
||||||
|
|
||||||
// insert BAR2
|
|
||||||
Bar bar2 = new Bar("BAR2");
|
|
||||||
barService.create(bar2);
|
|
||||||
|
|
||||||
// update BAR1
|
|
||||||
bar1.setName("BAR1b");
|
|
||||||
barService.update(bar1);
|
|
||||||
|
|
||||||
// get BAR1 and BAR2 from the DB and check the audit values
|
|
||||||
// detach instances from persistence context to make sure we fire db
|
|
||||||
em.detach(bar1);
|
|
||||||
em.detach(bar2);
|
|
||||||
bar1 = barService.findOne(bar1.getId());
|
|
||||||
bar2 = barService.findOne(bar2.getId());
|
|
||||||
|
|
||||||
assertNotNull(bar1);
|
|
||||||
assertNotNull(bar2);
|
|
||||||
assertEquals(OPERATION.UPDATE, bar1.getOperation());
|
|
||||||
assertEquals(OPERATION.INSERT, bar2.getOperation());
|
|
||||||
assertTrue(bar1.getTimestamp() > bar2.getTimestamp());
|
|
||||||
|
|
||||||
barService.deleteById(bar1.getId());
|
|
||||||
barService.deleteById(bar2.getId());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,76 +0,0 @@
|
|||||||
package com.baeldung.persistence.audit;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
|
||||||
import javax.persistence.EntityManagerFactory;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.service.IBarService;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.AfterClass;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.BeforeClass;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.security.test.context.support.WithMockUser;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class SpringDataJPABarAuditIntegrationTest {
|
|
||||||
|
|
||||||
private static Logger logger = LoggerFactory.getLogger(SpringDataJPABarAuditIntegrationTest.class);
|
|
||||||
|
|
||||||
@BeforeClass
|
|
||||||
public static void setUpBeforeClass() throws Exception {
|
|
||||||
logger.info("setUpBeforeClass()");
|
|
||||||
}
|
|
||||||
|
|
||||||
@AfterClass
|
|
||||||
public static void tearDownAfterClass() throws Exception {
|
|
||||||
logger.info("tearDownAfterClass()");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("barSpringDataJpaService")
|
|
||||||
private IBarService barService;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private EntityManagerFactory entityManagerFactory;
|
|
||||||
|
|
||||||
private EntityManager em;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() throws Exception {
|
|
||||||
logger.info("setUp()");
|
|
||||||
em = entityManagerFactory.createEntityManager();
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void tearDown() throws Exception {
|
|
||||||
logger.info("tearDown()");
|
|
||||||
em.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@WithMockUser(username = "tutorialuser")
|
|
||||||
public final void whenBarsModified_thenBarsAudited() {
|
|
||||||
Bar bar = new Bar("BAR1");
|
|
||||||
barService.create(bar);
|
|
||||||
assertEquals(bar.getCreatedDate(), bar.getModifiedDate());
|
|
||||||
assertEquals("tutorialuser", bar.getCreatedBy(), bar.getModifiedBy());
|
|
||||||
bar.setName("BAR2");
|
|
||||||
bar = barService.update(bar);
|
|
||||||
assertTrue(bar.getCreatedDate() < bar.getModifiedDate());
|
|
||||||
assertEquals("tutorialuser", bar.getCreatedBy(), bar.getModifiedBy());
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,9 +1,8 @@
|
|||||||
package com.baeldung.persistence.service;
|
package com.baeldung.persistence.dao.common;
|
||||||
|
|
||||||
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
import com.baeldung.persistence.model.Foo;
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
import com.baeldung.spring.PersistenceConfig;
|
||||||
|
import org.apache.commons.lang3.RandomStringUtils;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.SessionFactory;
|
import org.hibernate.SessionFactory;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
@ -17,18 +16,13 @@ import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
||||||
public class FooServiceBasicPersistenceIntegrationTest {
|
public class HibernateDaoIntegrationTest {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private SessionFactory sessionFactory;
|
private SessionFactory sessionFactory;
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IFooService fooService;
|
|
||||||
|
|
||||||
private Session session;
|
private Session session;
|
||||||
|
|
||||||
// tests
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public final void before() {
|
public final void before() {
|
||||||
session = sessionFactory.openSession();
|
session = sessionFactory.openSession();
|
||||||
@ -39,16 +33,14 @@ public class FooServiceBasicPersistenceIntegrationTest {
|
|||||||
session.close();
|
session.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
// tests
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public final void whenContextIsBootstrapped_thenNoExceptions() {
|
public final void whenContextIsBootstrapped_thenNoExceptions() {
|
||||||
//
|
//
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public final void whenEntityIsCreated_thenNoExceptions() {
|
public final void whenPersistEntity_thenSuccess() {
|
||||||
fooService.create(new Foo(randomAlphabetic(6)));
|
session.persist(new Foo(RandomStringUtils.randomAlphabetic(5).toUpperCase()));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -1,101 +0,0 @@
|
|||||||
package com.baeldung.persistence.hibernate;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import org.hibernate.HibernateException;
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.hibernate.Transaction;
|
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
|
||||||
|
|
||||||
public class FooFixtures {
|
|
||||||
private SessionFactory sessionFactory;
|
|
||||||
|
|
||||||
public FooFixtures(final SessionFactory sessionFactory) {
|
|
||||||
super();
|
|
||||||
|
|
||||||
this.sessionFactory = sessionFactory;
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
public void createBars() {
|
|
||||||
Session session = null;
|
|
||||||
Transaction tx = null;
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
tx = session.getTransaction();
|
|
||||||
try {
|
|
||||||
tx.begin();
|
|
||||||
for (int i = 156; i < 160; i++) {
|
|
||||||
final Bar bar = new Bar();
|
|
||||||
bar.setName("Bar_" + i);
|
|
||||||
final Foo foo = new Foo("Foo_" + (i + 120));
|
|
||||||
foo.setBar(bar);
|
|
||||||
session.save(foo);
|
|
||||||
final Foo foo2 = new Foo(null);
|
|
||||||
if (i % 2 == 0)
|
|
||||||
foo2.setName("LuckyFoo" + (i + 120));
|
|
||||||
foo2.setBar(bar);
|
|
||||||
session.save(foo2);
|
|
||||||
bar.getFooSet().add(foo);
|
|
||||||
bar.getFooSet().add(foo2);
|
|
||||||
session.merge(bar);
|
|
||||||
}
|
|
||||||
tx.commit();
|
|
||||||
session.flush();
|
|
||||||
} catch (final HibernateException he) {
|
|
||||||
if (tx != null)
|
|
||||||
tx.rollback();
|
|
||||||
System.out.println("Not able to open session");
|
|
||||||
he.printStackTrace();
|
|
||||||
} catch (final Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
} finally {
|
|
||||||
if (session != null)
|
|
||||||
session.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void createFoos() {
|
|
||||||
Session session = null;
|
|
||||||
Transaction tx = null;
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
tx = session.getTransaction();
|
|
||||||
final List<Foo> fooList = Lists.newArrayList();
|
|
||||||
for (int i = 35; i < 46; i++) {
|
|
||||||
|
|
||||||
final Foo foo = new Foo();
|
|
||||||
foo.setName("Foo_" + (i + 120));
|
|
||||||
final Bar bar = new Bar("bar_" + i);
|
|
||||||
bar.getFooSet().add(foo);
|
|
||||||
foo.setBar(bar);
|
|
||||||
fooList.add(foo);
|
|
||||||
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
tx.begin();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
|
|
||||||
session.save(foo.getBar());
|
|
||||||
session.save(foo);
|
|
||||||
}
|
|
||||||
tx.commit();
|
|
||||||
session.flush();
|
|
||||||
} catch (final HibernateException he) {
|
|
||||||
if (tx != null)
|
|
||||||
tx.rollback();
|
|
||||||
System.out.println("Not able to open session");
|
|
||||||
he.printStackTrace();
|
|
||||||
} catch (final Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
} finally {
|
|
||||||
if (session != null)
|
|
||||||
session.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,180 +0,0 @@
|
|||||||
package com.baeldung.persistence.hibernate;
|
|
||||||
|
|
||||||
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
|
||||||
import static org.hamcrest.Matchers.hasSize;
|
|
||||||
import static org.hamcrest.Matchers.lessThan;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import javax.persistence.Tuple;
|
|
||||||
import javax.persistence.criteria.CriteriaBuilder;
|
|
||||||
import javax.persistence.criteria.CriteriaQuery;
|
|
||||||
import javax.persistence.criteria.Root;
|
|
||||||
|
|
||||||
import org.hibernate.ScrollMode;
|
|
||||||
import org.hibernate.ScrollableResults;
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.persistence.service.IFooService;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
import com.google.common.collect.Lists;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class FooPaginationPersistenceIntegrationTest {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IFooService fooService;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private SessionFactory sessionFactory;
|
|
||||||
|
|
||||||
private Session session;
|
|
||||||
|
|
||||||
// tests
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public final void before() {
|
|
||||||
final int minimalNumberOfEntities = 25;
|
|
||||||
if (fooService.findAll().size() <= minimalNumberOfEntities) {
|
|
||||||
for (int i = 0; i < minimalNumberOfEntities; i++) {
|
|
||||||
fooService.create(new Foo(randomAlphabetic(6)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public final void after() {
|
|
||||||
session.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
// tests
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenContextIsBootstrapped_thenNoExceptions() {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Test
|
|
||||||
public final void whenRetrievingPaginatedEntities_thenCorrectSize() {
|
|
||||||
final int pageNumber = 1;
|
|
||||||
final int pageSize = 10;
|
|
||||||
final List<Foo> fooList = session.createQuery("From Foo").setFirstResult((pageNumber - 1) * pageSize).setMaxResults(pageSize).getResultList();
|
|
||||||
assertThat(fooList, hasSize(pageSize));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Test
|
|
||||||
public final void whenRetrievingAllPages_thenCorrect() {
|
|
||||||
int pageNumber = 1;
|
|
||||||
final int pageSize = 10;
|
|
||||||
|
|
||||||
final String countQ = "Select count (f.id) from Foo f";
|
|
||||||
final Long countResult = (Long) session.createQuery(countQ).uniqueResult();
|
|
||||||
|
|
||||||
final List<Foo> fooList = Lists.newArrayList();
|
|
||||||
int totalEntities = 0;
|
|
||||||
while (totalEntities < countResult) {
|
|
||||||
fooList.addAll(session.createQuery("From Foo").setFirstResult((pageNumber - 1) * pageSize).setMaxResults(pageSize).getResultList());
|
|
||||||
totalEntities = fooList.size();
|
|
||||||
pageNumber++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Test
|
|
||||||
public final void whenRetrievingLastPage_thenCorrectSize() {
|
|
||||||
final int pageSize = 10;
|
|
||||||
|
|
||||||
final String countQ = "Select count (f.id) from Foo f";
|
|
||||||
final Long countResults = (Long) session.createQuery(countQ).uniqueResult();
|
|
||||||
final int lastPageNumber = (int) ((countResults / pageSize) + 1);
|
|
||||||
|
|
||||||
final List<Foo> lastPage = session.createQuery("From Foo").setFirstResult((lastPageNumber - 1) * pageSize).setMaxResults(pageSize).getResultList();
|
|
||||||
|
|
||||||
assertThat(lastPage, hasSize(lessThan(pageSize + 1)));
|
|
||||||
}
|
|
||||||
|
|
||||||
// testing - scrollable
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void givenUsingTheScrollableApi_whenRetrievingPaginatedData_thenCorrect() {
|
|
||||||
final int pageSize = 10;
|
|
||||||
final String hql = "FROM Foo f order by f.name";
|
|
||||||
|
|
||||||
final ScrollableResults resultScroll = session.createQuery(hql).scroll(ScrollMode.FORWARD_ONLY);
|
|
||||||
|
|
||||||
// resultScroll.last();
|
|
||||||
// final int totalResults = resultScroll.getRowNumber() + 1;
|
|
||||||
|
|
||||||
resultScroll.first();
|
|
||||||
resultScroll.scroll(0);
|
|
||||||
final List<Foo> fooPage = Lists.newArrayList();
|
|
||||||
int i = 0;
|
|
||||||
while (pageSize > i++) {
|
|
||||||
fooPage.add((Foo) resultScroll.get(0));
|
|
||||||
if (!resultScroll.next()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
assertThat(fooPage, hasSize(lessThan(10 + 1)));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Test
|
|
||||||
public final void givenUsingTheCriteriaApi_whenRetrievingFirstPage_thenCorrect() {
|
|
||||||
final int pageSize = 10;
|
|
||||||
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Foo> criteriaItem = builder.createQuery(Foo.class);
|
|
||||||
Root<Foo> rootItem = criteriaItem.from(Foo.class);
|
|
||||||
criteriaItem.select(rootItem);
|
|
||||||
final List<Foo> firstPage = session.createQuery(criteriaItem).setFirstResult(0).setMaxResults(pageSize).getResultList();
|
|
||||||
|
|
||||||
assertThat(firstPage, hasSize(pageSize));
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
@Test
|
|
||||||
public final void givenUsingTheCriteriaApi_whenRetrievingPaginatedData_thenCorrect() {
|
|
||||||
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Tuple> criteriaItem = builder.createQuery(Tuple.class);
|
|
||||||
Root<Foo> rootItem = criteriaItem.from(Foo.class);
|
|
||||||
criteriaItem.multiselect(builder.count(rootItem));
|
|
||||||
final List<Tuple> itemProjected = session.createQuery(criteriaItem).getResultList();
|
|
||||||
final Long count = (Long) itemProjected.get(0).get(0);
|
|
||||||
|
|
||||||
int pageNumber = 1;
|
|
||||||
final int pageSize = 10;
|
|
||||||
final List<Foo> fooList = Lists.newArrayList();
|
|
||||||
|
|
||||||
CriteriaBuilder builderFoo = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Foo> criteriaFoo = builderFoo.createQuery(Foo.class);
|
|
||||||
Root<Foo> rootFoo = criteriaFoo.from(Foo.class);
|
|
||||||
criteriaFoo.select(rootFoo);
|
|
||||||
|
|
||||||
int totalEntities = 0;
|
|
||||||
while (totalEntities < count.intValue()) {
|
|
||||||
fooList.addAll(session.createQuery(criteriaFoo).setFirstResult((pageNumber - 1) * pageSize).setMaxResults(pageSize).getResultList());
|
|
||||||
totalEntities = fooList.size();
|
|
||||||
pageNumber++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,177 +0,0 @@
|
|||||||
package com.baeldung.persistence.hibernate;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertNull;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import javax.persistence.criteria.CriteriaBuilder;
|
|
||||||
import javax.persistence.criteria.CriteriaQuery;
|
|
||||||
import javax.persistence.criteria.Order;
|
|
||||||
import javax.persistence.criteria.Root;
|
|
||||||
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Bar;
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public class FooSortingPersistenceIntegrationTest {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private SessionFactory sessionFactory;
|
|
||||||
|
|
||||||
private Session session;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void before() {
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
|
|
||||||
session.beginTransaction();
|
|
||||||
|
|
||||||
final FooFixtures fooData = new FooFixtures(sessionFactory);
|
|
||||||
fooData.createBars();
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void after() {
|
|
||||||
session.getTransaction().commit();
|
|
||||||
session.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQlSortingByOneAttribute_thenPrintSortedResults() {
|
|
||||||
final String hql = "FROM Foo f ORDER BY f.name";
|
|
||||||
final List<Foo> fooList = session.createQuery(hql).getResultList();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Name: " + foo.getName() + ", Id: " + foo.getId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQlSortingByStringNullLast_thenLastNull() {
|
|
||||||
final String hql = "FROM Foo f ORDER BY f.name NULLS LAST";
|
|
||||||
final List<Foo> fooList = session.createQuery(hql).getResultList();
|
|
||||||
|
|
||||||
assertNull(fooList.get(fooList.toArray().length - 1).getName());
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Name: " + foo.getName() + ", Id: " + foo.getId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenSortingByStringNullsFirst_thenReturnNullsFirst() {
|
|
||||||
final String hql = "FROM Foo f ORDER BY f.name NULLS FIRST";
|
|
||||||
final List<Foo> fooList = session.createQuery(hql).getResultList();
|
|
||||||
assertNull(fooList.get(0).getName());
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Name:" + foo.getName());
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQlSortingByOneAttribute_andOrderDirection_thenPrintSortedResults() {
|
|
||||||
final String hql = "FROM Foo f ORDER BY f.name ASC";
|
|
||||||
final List<Foo> fooList = session.createQuery(hql).getResultList();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Name: " + foo.getName() + ", Id: " + foo.getId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQlSortingByMultipleAttributes_thenSortedResults() {
|
|
||||||
final String hql = "FROM Foo f ORDER BY f.name, f.id";
|
|
||||||
final List<Foo> fooList = session.createQuery(hql).getResultList();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Name: " + foo.getName() + ", Id: " + foo.getId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQlSortingByMultipleAttributes_andOrderDirection_thenPrintSortedResults() {
|
|
||||||
final String hql = "FROM Foo f ORDER BY f.name DESC, f.id ASC";
|
|
||||||
final List<Foo> fooList = session.createQuery(hql).getResultList();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Name: " + foo.getName() + ", Id: " + foo.getId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQLCriteriaSortingByOneAttr_thenPrintSortedResults() {
|
|
||||||
List<Order> listOrders = new ArrayList<Order>();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Foo> criteriaItem = builder.createQuery(Foo.class);
|
|
||||||
Root<Foo> rootItem = criteriaItem.from(Foo.class);
|
|
||||||
listOrders.add(builder.asc(rootItem.get("id")));
|
|
||||||
criteriaItem.orderBy(listOrders.toArray(new Order[] {}));
|
|
||||||
final List<Foo> fooList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Id: " + foo.getId() + ", FirstName: " + foo.getName());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenHQLCriteriaSortingByMultipAttr_thenSortedResults() {
|
|
||||||
List<Order> listOrders = new ArrayList<Order>();
|
|
||||||
CriteriaBuilder builder = session.getCriteriaBuilder();
|
|
||||||
CriteriaQuery<Foo> criteriaItem = builder.createQuery(Foo.class);
|
|
||||||
Root<Foo> rootItem = criteriaItem.from(Foo.class);
|
|
||||||
listOrders.add(builder.asc(rootItem.get("name")));
|
|
||||||
listOrders.add(builder.asc(rootItem.get("id")));
|
|
||||||
criteriaItem.orderBy(listOrders.toArray(new Order[] {}));
|
|
||||||
final List<Foo> fooList = session.createQuery(criteriaItem).getResultList();
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Id: " + foo.getId() + ", FirstName: " + foo.getName());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*@Test
|
|
||||||
public final void whenCriteriaSortingStringNullsLastAsc_thenNullsLast() {
|
|
||||||
final Criteria criteria = session.createCriteria(Foo.class, "FOO");
|
|
||||||
criteria.addOrder(Order.asc("name").nulls(NullPrecedence.LAST));
|
|
||||||
final List<Foo> fooList = criteria.list();
|
|
||||||
assertNull(fooList.get(fooList.toArray().length - 1).getName());
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Id: " + foo.getId() + ", FirstName: " + foo.getName());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenCriteriaSortingStringNullsFirstDesc_thenNullsFirst() {
|
|
||||||
final Criteria criteria = session.createCriteria(Foo.class, "FOO");
|
|
||||||
criteria.addOrder(Order.desc("name").nulls(NullPrecedence.FIRST));
|
|
||||||
final List<Foo> fooList = criteria.list();
|
|
||||||
assertNull(fooList.get(0).getName());
|
|
||||||
for (final Foo foo : fooList) {
|
|
||||||
System.out.println("Id: " + foo.getId() + ", FirstName: " + foo.getName());
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenSortingBars_thenBarsWithSortedFoos() {
|
|
||||||
final String hql = "FROM Bar b ORDER BY b.id";
|
|
||||||
final List<Bar> barList = session.createQuery(hql).getResultList();
|
|
||||||
for (final Bar bar : barList) {
|
|
||||||
final Set<Foo> fooSet = bar.getFooSet();
|
|
||||||
System.out.println("Bar Id:" + bar.getId());
|
|
||||||
for (final Foo foo : fooSet) {
|
|
||||||
System.out.println("FooName:" + foo.getName());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,270 +0,0 @@
|
|||||||
package com.baeldung.persistence.save;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Person;
|
|
||||||
import org.hibernate.HibernateException;
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.hibernate.TransactionException;
|
|
||||||
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
|
||||||
import org.hibernate.cfg.Configuration;
|
|
||||||
import org.hibernate.dialect.HSQLDialect;
|
|
||||||
import org.hibernate.service.ServiceRegistry;
|
|
||||||
import org.junit.*;
|
|
||||||
|
|
||||||
import javax.persistence.PersistenceException;
|
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Testing specific implementation details for different methods: persist, save,
|
|
||||||
* merge, update, saveOrUpdate.
|
|
||||||
*/
|
|
||||||
public class SaveMethodIntegrationTest {
|
|
||||||
|
|
||||||
private static SessionFactory sessionFactory;
|
|
||||||
|
|
||||||
private Session session;
|
|
||||||
|
|
||||||
@BeforeClass
|
|
||||||
public static void beforeTests() {
|
|
||||||
Configuration configuration = new Configuration().addAnnotatedClass(Person.class).setProperty("hibernate.dialect", HSQLDialect.class.getName()).setProperty("hibernate.connection.driver_class", org.hsqldb.jdbcDriver.class.getName())
|
|
||||||
.setProperty("hibernate.connection.url", "jdbc:hsqldb:mem:test").setProperty("hibernate.connection.username", "sa").setProperty("hibernate.connection.password", "").setProperty("hibernate.hbm2ddl.auto", "update");
|
|
||||||
ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build();
|
|
||||||
sessionFactory = configuration.buildSessionFactory(serviceRegistry);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
session.beginTransaction();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenPersistTransient_thenSavedToDatabaseOnCommit() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.persist(person);
|
|
||||||
|
|
||||||
session.getTransaction().commit();
|
|
||||||
session.close();
|
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
session.beginTransaction();
|
|
||||||
|
|
||||||
assertNotNull(session.get(Person.class, person.getId()));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenPersistPersistent_thenNothingHappens() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
|
|
||||||
session.persist(person);
|
|
||||||
Long id1 = person.getId();
|
|
||||||
|
|
||||||
session.persist(person);
|
|
||||||
Long id2 = person.getId();
|
|
||||||
|
|
||||||
assertEquals(id1, id2);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = PersistenceException.class)
|
|
||||||
public void whenPersistDetached_thenThrowsException() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.persist(person);
|
|
||||||
session.evict(person);
|
|
||||||
|
|
||||||
session.persist(person);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSaveTransient_thenIdGeneratedImmediately() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
|
|
||||||
assertNull(person.getId());
|
|
||||||
|
|
||||||
Long id = (Long) session.save(person);
|
|
||||||
|
|
||||||
assertNotNull(id);
|
|
||||||
|
|
||||||
session.getTransaction().commit();
|
|
||||||
session.close();
|
|
||||||
|
|
||||||
assertEquals(id, person.getId());
|
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
session.beginTransaction();
|
|
||||||
|
|
||||||
assertNotNull(session.get(Person.class, person.getId()));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSavePersistent_thenNothingHappens() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
Long id1 = (Long) session.save(person);
|
|
||||||
Long id2 = (Long) session.save(person);
|
|
||||||
assertEquals(id1, id2);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSaveDetached_thenNewInstancePersisted() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
Long id1 = (Long) session.save(person);
|
|
||||||
session.evict(person);
|
|
||||||
|
|
||||||
Long id2 = (Long) session.save(person);
|
|
||||||
assertNotEquals(id1, id2);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenMergeDetached_thenEntityUpdatedFromDatabase() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.save(person);
|
|
||||||
session.flush();
|
|
||||||
session.evict(person);
|
|
||||||
|
|
||||||
person.setName("Mary");
|
|
||||||
Person mergedPerson = (Person) session.merge(person);
|
|
||||||
|
|
||||||
assertNotSame(person, mergedPerson);
|
|
||||||
assertEquals("Mary", mergedPerson.getName());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenMergeTransient_thenNewEntitySavedToDatabase() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
Person mergedPerson = (Person) session.merge(person);
|
|
||||||
|
|
||||||
session.getTransaction().commit();
|
|
||||||
session.beginTransaction();
|
|
||||||
|
|
||||||
assertNull(person.getId());
|
|
||||||
assertNotNull(mergedPerson.getId());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenMergePersistent_thenReturnsSameObject() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.save(person);
|
|
||||||
|
|
||||||
Person mergedPerson = (Person) session.merge(person);
|
|
||||||
|
|
||||||
assertSame(person, mergedPerson);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenUpdateDetached_thenEntityUpdatedFromDatabase() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.save(person);
|
|
||||||
session.evict(person);
|
|
||||||
|
|
||||||
person.setName("Mary");
|
|
||||||
session.update(person);
|
|
||||||
assertEquals("Mary", person.getName());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = HibernateException.class)
|
|
||||||
public void whenUpdateTransient_thenThrowsException() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.update(person);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenUpdatePersistent_thenNothingHappens() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.save(person);
|
|
||||||
|
|
||||||
session.update(person);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSaveOrUpdateDetached_thenEntityUpdatedFromDatabase() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.save(person);
|
|
||||||
session.evict(person);
|
|
||||||
|
|
||||||
person.setName("Mary");
|
|
||||||
session.saveOrUpdate(person);
|
|
||||||
assertEquals("Mary", person.getName());
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSaveOrUpdateTransient_thenSavedToDatabaseOnCommit() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.saveOrUpdate(person);
|
|
||||||
|
|
||||||
session.getTransaction().commit();
|
|
||||||
session.close();
|
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
session.beginTransaction();
|
|
||||||
|
|
||||||
assertNotNull(session.get(Person.class, person.getId()));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSaveOrUpdatePersistent_thenNothingHappens() {
|
|
||||||
|
|
||||||
Person person = new Person();
|
|
||||||
person.setName("John");
|
|
||||||
session.save(person);
|
|
||||||
|
|
||||||
session.saveOrUpdate(person);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void tearDown() {
|
|
||||||
try {
|
|
||||||
session.getTransaction().commit();
|
|
||||||
session.close();
|
|
||||||
} catch (TransactionException ex) {
|
|
||||||
ex.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@AfterClass
|
|
||||||
public static void afterTests() {
|
|
||||||
sessionFactory.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,63 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
|
||||||
import org.springframework.dao.DataAccessException;
|
|
||||||
import org.springframework.dao.DataIntegrityViolationException;
|
|
||||||
import org.springframework.dao.InvalidDataAccessApiUsageException;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class FooServicePersistenceIntegrationTest {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
@Qualifier("fooHibernateService")
|
|
||||||
private IFooService service;
|
|
||||||
|
|
||||||
// tests
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenContextIsBootstrapped_thenNoExceptions() {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenEntityIsCreated_thenNoExceptions() {
|
|
||||||
service.create(new Foo(randomAlphabetic(6)));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = DataIntegrityViolationException.class)
|
|
||||||
@Ignore("work in progress")
|
|
||||||
public final void whenInvalidEntityIsCreated_thenDataException() {
|
|
||||||
service.create(new Foo());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = DataIntegrityViolationException.class)
|
|
||||||
public final void whenEntityWithLongNameIsCreated_thenDataException() {
|
|
||||||
service.create(new Foo(randomAlphabetic(2048)));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = InvalidDataAccessApiUsageException.class)
|
|
||||||
@Ignore("Right now, persist has saveOrUpdate semantics, so this will no longer fail")
|
|
||||||
public final void whenSameEntityIsCreatedTwice_thenDataException() {
|
|
||||||
final Foo entity = new Foo(randomAlphabetic(8));
|
|
||||||
service.create(entity);
|
|
||||||
service.create(entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = DataAccessException.class)
|
|
||||||
public final void temp_whenInvalidEntityIsCreated_thenDataException() {
|
|
||||||
service.create(new Foo(randomAlphabetic(2048)));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,112 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.hibernate.Session;
|
|
||||||
import org.hibernate.SessionFactory;
|
|
||||||
import org.hibernate.exception.SQLGrammarException;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Assume;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Foo;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class FooStoredProceduresIntegrationTest {
|
|
||||||
|
|
||||||
private static final Logger LOGGER = LoggerFactory.getLogger(FooStoredProceduresIntegrationTest.class);
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private SessionFactory sessionFactory;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IFooService fooService;
|
|
||||||
|
|
||||||
private Session session;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public final void before() {
|
|
||||||
session = sessionFactory.openSession();
|
|
||||||
Assume.assumeTrue(getAllFoosExists());
|
|
||||||
Assume.assumeTrue(getFoosByNameExists());
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean getFoosByNameExists() {
|
|
||||||
try {
|
|
||||||
session.createQuery("CALL GetAllFoos()", Foo.class).getResultList();
|
|
||||||
return true;
|
|
||||||
} catch (SQLGrammarException e) {
|
|
||||||
LOGGER.error("WARNING : GetFoosByName() Procedure is may be missing ", e);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean getAllFoosExists() {
|
|
||||||
try {
|
|
||||||
session.createQuery("CALL GetAllFoos()", Foo.class).getResultList();
|
|
||||||
return true;
|
|
||||||
} catch (SQLGrammarException e) {
|
|
||||||
LOGGER.error("WARNING : GetAllFoos() Procedure is may be missing ", e);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public final void after() {
|
|
||||||
session.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void getAllFoosUsingStoredProcedures() {
|
|
||||||
|
|
||||||
fooService.create(new Foo(randomAlphabetic(6)));
|
|
||||||
|
|
||||||
// Stored procedure getAllFoos using createSQLQuery
|
|
||||||
List<Foo> allFoos = session.createQuery("CALL GetAllFoos()", Foo.class).getResultList();
|
|
||||||
for (Foo foo : allFoos) {
|
|
||||||
LOGGER.info("getAllFoos() SQL Query result : {}", foo.getName());
|
|
||||||
}
|
|
||||||
assertEquals(allFoos.size(), fooService.findAll().size());
|
|
||||||
|
|
||||||
// Stored procedure getAllFoos using a Named Query
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
List<Foo> allFoos2 = session.getNamedQuery("callGetAllFoos").getResultList();
|
|
||||||
for (Foo foo : allFoos2) {
|
|
||||||
LOGGER.info("getAllFoos() NamedQuery result : {}", foo.getName());
|
|
||||||
}
|
|
||||||
assertEquals(allFoos2.size(), fooService.findAll().size());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void getFoosByNameUsingStoredProcedures() {
|
|
||||||
|
|
||||||
fooService.create(new Foo("NewFooName"));
|
|
||||||
|
|
||||||
// Stored procedure getFoosByName using createSQLQuery()
|
|
||||||
List<Foo> allFoosByName = session.createQuery("CALL GetFoosByName(:fooName)", Foo.class).setParameter("fooName", "NewFooName").getResultList();
|
|
||||||
for (Foo foo : allFoosByName) {
|
|
||||||
LOGGER.info("getFoosByName() using SQL Query : found => {}", foo.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Stored procedure getFoosByName using getNamedQuery()
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
List<Foo> allFoosByName2 = session.getNamedQuery("callGetFoosByName").setParameter("fooName", "NewFooName").getResultList();
|
|
||||||
for (Foo foo : allFoosByName2) {
|
|
||||||
LOGGER.info("getFoosByName() using Native Query : found => {}", foo.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,69 +0,0 @@
|
|||||||
package com.baeldung.persistence.service;
|
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Child;
|
|
||||||
import com.baeldung.persistence.model.Parent;
|
|
||||||
import com.baeldung.spring.PersistenceConfig;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.dao.DataIntegrityViolationException;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = { PersistenceConfig.class }, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class ParentServicePersistenceIntegrationTest {
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IParentService service;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private IChildService childService;
|
|
||||||
|
|
||||||
// tests
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenContextIsBootstrapped_thenNoExceptions() {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenOneToOneEntitiesAreCreated_thenNoExceptions() {
|
|
||||||
final Child childEntity = new Child();
|
|
||||||
childService.create(childEntity);
|
|
||||||
|
|
||||||
final Parent parentEntity = new Parent(childEntity);
|
|
||||||
service.create(parentEntity);
|
|
||||||
|
|
||||||
System.out.println("Child = " + childService.findOne(childEntity.getId()));
|
|
||||||
System.out.println("Child - parent = " + childService.findOne(childEntity.getId()).getParent());
|
|
||||||
|
|
||||||
System.out.println("Parent = " + service.findOne(parentEntity.getId()));
|
|
||||||
System.out.println("Parent - child = " + service.findOne(parentEntity.getId()).getChild());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = DataIntegrityViolationException.class)
|
|
||||||
public final void whenChildIsDeletedWhileParentStillHasForeignKeyToIt_thenDataException() {
|
|
||||||
final Child childEntity = new Child();
|
|
||||||
childService.create(childEntity);
|
|
||||||
|
|
||||||
final Parent parentEntity = new Parent(childEntity);
|
|
||||||
service.create(parentEntity);
|
|
||||||
|
|
||||||
childService.delete(childEntity);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public final void whenChildIsDeletedAfterTheParent_thenNoExceptions() {
|
|
||||||
final Child childEntity = new Child();
|
|
||||||
childService.create(childEntity);
|
|
||||||
|
|
||||||
final Parent parentEntity = new Parent(childEntity);
|
|
||||||
service.create(parentEntity);
|
|
||||||
|
|
||||||
service.delete(parentEntity);
|
|
||||||
childService.delete(childEntity);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,22 +0,0 @@
|
|||||||
<?xml version="1.0"?>
|
|
||||||
<!DOCTYPE hibernate-mapping PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
|
|
||||||
<hibernate-mapping>
|
|
||||||
<class name="com.baeldung.hibernate.criteria.model.Item" table="ITEM">
|
|
||||||
<id name="itemId" type="java.lang.Integer">
|
|
||||||
<column name="ITEM_ID" />
|
|
||||||
<generator class="identity" />
|
|
||||||
</id>
|
|
||||||
<property name="itemDescription" type="string">
|
|
||||||
<column name="ITEM_DESC" length="100" />
|
|
||||||
</property>
|
|
||||||
<property name="itemPrice" type="java.lang.Integer">
|
|
||||||
<column name="ITEM_PRICE" not-null="true" />
|
|
||||||
</property>
|
|
||||||
<property name="itemName" type="string">
|
|
||||||
<column name="ITEM_NAME" not-null="true" />
|
|
||||||
</property>
|
|
||||||
</class>
|
|
||||||
|
|
||||||
</hibernate-mapping>
|
|
@ -1,16 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!DOCTYPE hibernate-configuration PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
|
|
||||||
|
|
||||||
<hibernate-configuration>
|
|
||||||
<session-factory>
|
|
||||||
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
|
|
||||||
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
|
|
||||||
<property name="hibernate.connection.username">root</property>
|
|
||||||
<property name="hibernate.connection.password">root</property>
|
|
||||||
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
|
|
||||||
<property name="show_sql">true</property>
|
|
||||||
<mapping resource="com/baeldung/hibernate/criteria/model/Item.hbm.xml" />
|
|
||||||
</session-factory>
|
|
||||||
</hibernate-configuration>
|
|
@ -1,18 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!DOCTYPE hibernate-configuration PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
|
|
||||||
|
|
||||||
<hibernate-configuration>
|
|
||||||
<session-factory>
|
|
||||||
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
|
|
||||||
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
|
|
||||||
<property name="hibernate.connection.username">root</property>
|
|
||||||
<property name="hibernate.connection.password">root</property>
|
|
||||||
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
|
|
||||||
<property name="show_sql">true</property>
|
|
||||||
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.UserEager" />
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.OrderDetailEager" />
|
|
||||||
</session-factory>
|
|
||||||
</hibernate-configuration>
|
|
@ -1,18 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!DOCTYPE hibernate-configuration PUBLIC
|
|
||||||
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
|
|
||||||
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
|
|
||||||
|
|
||||||
<hibernate-configuration>
|
|
||||||
<session-factory>
|
|
||||||
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
|
|
||||||
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>
|
|
||||||
<property name="hibernate.connection.username">root</property>
|
|
||||||
<property name="hibernate.connection.password">root</property>
|
|
||||||
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
|
|
||||||
<property name="show_sql">true</property>
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.UserLazy" />
|
|
||||||
<mapping class="com.baeldung.hibernate.fetching.model.OrderDetail" />
|
|
||||||
|
|
||||||
</session-factory>
|
|
||||||
</hibernate-configuration>
|
|
Loading…
x
Reference in New Issue
Block a user