6 - SQM based on JPA type system

This commit is contained in:
Andrea Boriero 2019-07-18 14:37:20 +01:00
parent 911c0220fe
commit b05029e6ac
2 changed files with 191 additions and 63 deletions

View File

@ -44,7 +44,13 @@ public class SessionFactorySerializationTest extends BaseUnitTestCase {
// deregister under this uuid... // deregister under this uuid...
SessionFactoryRegistry.INSTANCE.removeSessionFactory( uuid, NAME, false, null ); SessionFactoryRegistry.INSTANCE.removeSessionFactory( uuid, NAME, false, null );
// and then register under a different uuid... // and then register under a different uuid...
SessionFactoryRegistry.INSTANCE.addSessionFactory( "some-other-uuid", NAME, false, factory, null ); SessionFactoryRegistry.INSTANCE.addSessionFactory(
"some-other-uuid",
NAME,
false,
(SessionFactoryImplementor) factory,
null
);
SessionFactory factory2 = (SessionFactory) SerializationHelper.clone( factory ); SessionFactory factory2 = (SessionFactory) SerializationHelper.clone( factory );
assertSame( factory, factory2 ); assertSame( factory, factory2 );
@ -69,7 +75,13 @@ public class SessionFactorySerializationTest extends BaseUnitTestCase {
// deregister under this uuid... // deregister under this uuid...
SessionFactoryRegistry.INSTANCE.removeSessionFactory( uuid, null, false, null ); SessionFactoryRegistry.INSTANCE.removeSessionFactory( uuid, null, false, null );
// and then register under a different uuid... // and then register under a different uuid...
SessionFactoryRegistry.INSTANCE.addSessionFactory( "some-other-uuid", null, false, factory, null ); SessionFactoryRegistry.INSTANCE.addSessionFactory(
"some-other-uuid",
null,
false,
(SessionFactoryImplementor) factory,
null
);
try { try {
SerializationHelper.clone( factory ); SerializationHelper.clone( factory );

View File

@ -15,6 +15,13 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Join;
import javax.persistence.criteria.JoinType;
import javax.persistence.criteria.Root;
import javax.persistence.criteria.Subquery;
import org.hibernate.FetchMode; import org.hibernate.FetchMode;
import org.hibernate.Hibernate; import org.hibernate.Hibernate;
import org.hibernate.Session; import org.hibernate.Session;
@ -26,13 +33,17 @@ import org.hibernate.dialect.IngresDialect;
import org.hibernate.dialect.SybaseASE15Dialect; import org.hibernate.dialect.SybaseASE15Dialect;
import org.hibernate.engine.spi.SessionImplementor; import org.hibernate.engine.spi.SessionImplementor;
import org.hibernate.persister.collection.CollectionPersister; import org.hibernate.persister.collection.CollectionPersister;
import org.hibernate.query.Query;
import org.hibernate.transform.DistinctRootEntityResultTransformer; import org.hibernate.transform.DistinctRootEntityResultTransformer;
import org.hibernate.testing.SkipForDialect; import org.hibernate.testing.SkipForDialect;
import org.hibernate.testing.TestForIssue; import org.hibernate.testing.TestForIssue;
import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase; import org.hibernate.testing.junit4.BaseNonConfigCoreFunctionalTestCase;
import org.hibernate.test.annotations.any.Property;
import org.junit.Test; import org.junit.Test;
import org.apache.xpath.operations.Or;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertSame; import static org.junit.Assert.assertSame;
@ -201,7 +212,7 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
assertTrue( "Incorrect collectionfilter count", result.getOrders().size() == 1 ); assertTrue( "Incorrect collectionfilter count", result.getOrders().size() == 1 );
log.info( "HQL against Product..." ); log.info( "HQL against Product..." );
results = session.createQuery( "from Product as p where p.stockNumber = ?1" ).setInteger( 1, 124 ).list(); results = session.createQuery( "from Product as p where p.stockNumber = ?1" ).setParameter( 1, 124 ).list();
assertTrue( results.size() == 1 ); assertTrue( results.size() == 1 );
session.close(); session.close();
@ -246,16 +257,26 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
.setParameter( "asOfDate", testData.lastMonth.getTime() ); .setParameter( "asOfDate", testData.lastMonth.getTime() );
log.info("Criteria query against Salesperson..."); log.info("Criteria query against Salesperson...");
List salespersons = session.createCriteria( Salesperson.class ) CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
.setFetchMode( "orders", FetchMode.JOIN ) CriteriaQuery<Salesperson> criteria = criteriaBuilder.createQuery( Salesperson.class );
.list(); Root<Salesperson> from = criteria.from( Salesperson.class );
from.fetch( "orders", JoinType.LEFT );
List salespersons = session.createQuery( criteria ).list();
// List salespersons = session.createCriteria( Salesperson.class )
// .setFetchMode( "orders", FetchMode.JOIN )
// .list();
assertEquals( "Incorrect salesperson count", 1, salespersons.size() ); assertEquals( "Incorrect salesperson count", 1, salespersons.size() );
assertEquals( "Incorrect order count", 1, ( ( Salesperson ) salespersons.get( 0 ) ).getOrders().size() ); assertEquals( "Incorrect order count", 1, ( ( Salesperson ) salespersons.get( 0 ) ).getOrders().size() );
log.info("Criteria query against Product..."); log.info("Criteria query against Product...");
List products = session.createCriteria( Product.class ) CriteriaQuery<Product> productCriteria = criteriaBuilder.createQuery( Product.class );
.add( Restrictions.eq( "stockNumber", 124 ) ) Root<Product> productRoot = productCriteria.from( Product.class );
.list(); productCriteria.where( criteriaBuilder.equal( productRoot.get( "stockNumber" ), 124 ) );
List products = session.createQuery( productCriteria ).list();
// List products = session.createCriteria( Product.class )
// .add( Restrictions.eq( "stockNumber", 124 ) )
// .list();
assertEquals( "Incorrect product count", 1, products.size() ); assertEquals( "Incorrect product count", 1, products.size() );
session.close(); session.close();
@ -268,21 +289,32 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
testData.prepare(); testData.prepare();
// the subquery... // the subquery...
DetachedCriteria subquery = DetachedCriteria.forClass( Salesperson.class ) // DetachedCriteria subquery = DetachedCriteria.forClass( Salesperson.class )
.setProjection( Property.forName( "name" ) ); // .setProjection( Property.forName( "name" ) );
CriteriaBuilder detachedCriteriaBuilder = sessionFactory().getCriteriaBuilder();
CriteriaQuery<Salesperson> query = detachedCriteriaBuilder.createQuery( Salesperson.class );
Subquery<String> subquery = query.subquery( String.class );
Root<Salesperson> salespersonRoot = subquery.from( Salesperson.class );
subquery.select( salespersonRoot.get( "name" ) );
Session session = openSession();
session.beginTransaction(); inTransaction(
session -> {
session.enableFilter( "fulfilledOrders" ).setParameter( "asOfDate", testData.lastMonth.getTime() ); session.enableFilter( "fulfilledOrders" ).setParameter( "asOfDate", testData.lastMonth.getTime() );
session.enableFilter( "regionlist" ).setParameterList( "regions", new String[] {"APAC"} ); session.enableFilter( "regionlist" ).setParameterList( "regions", new String[] {"APAC"} );
List result = session.createCriteria( Order.class ) CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
.add( Subqueries.in( "steve", subquery ) ) CriteriaQuery<Order> criteria = criteriaBuilder.createQuery( Order.class );
.list(); criteria.from( Order.class );
assertEquals( 1, result.size() ); criteria.where( criteriaBuilder.in( subquery ).value( "steve" ) );
List result = session.createQuery( criteria ).list();
session.getTransaction().commit(); // List result = session.createCriteria( Order.class )
session.close(); // .add( Subqueries.in( "steve", subquery ) )
// .list();
assertEquals( 1, result.size() );
}
);
testData.release(); testData.release();
} }
@ -300,12 +332,24 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("region").setParameter("region", "APAC"); session.enableFilter("region").setParameter("region", "APAC");
log.info("Criteria query against Department with a subquery on Salesperson in the APAC reqion..."); log.info("Criteria query against Department with a subquery on Salesperson in the APAC reqion...");
DetachedCriteria salespersonSubquery = DetachedCriteria.forClass(Salesperson.class) // DetachedCriteria salespersonSubquery = DetachedCriteria.forClass(Salesperson.class)
.add(Restrictions.eq("name", "steve")) // .add(Restrictions.eq("name", "steve"))
.setProjection(Property.forName("department")); // .setProjection(Property.forName("department"));
CriteriaBuilder detachedCriteriaBuilder = sessionFactory().getCriteriaBuilder();
Subquery<Department> subquery = detachedCriteriaBuilder.createQuery( Salesperson.class ).subquery( Department.class );
Root<Salesperson> subqueryRoot = subquery.from( Salesperson.class );
subquery.where( detachedCriteriaBuilder.equal( subqueryRoot.get("name"), "steve") );
subquery.select( subqueryRoot.get( "department" ) );
Criteria departmentsQuery = session.createCriteria(Department.class).add(Subqueries.propertyIn("id", salespersonSubquery)); CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
List departments = departmentsQuery.list(); CriteriaQuery<Department> criteria = criteriaBuilder.createQuery( Department.class );
criteria.where( criteriaBuilder.in( criteria.from( Department.class ).get( "id" ) ).value( subquery ) );
Query<Department> departmentsQuery = session.createQuery( criteria );
List<Department> departments = departmentsQuery.list();
// Criteria departmentsQuery = session.createCriteria(Department.class).add(Subqueries.propertyIn("id", salespersonSubquery));
// List departments = departmentsQuery.list();
assertEquals("Incorrect department count", 1, departments.size()); assertEquals("Incorrect department count", 1, departments.size());
@ -319,16 +363,37 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
log.info("Criteria query against Order with a subquery for line items with a subquery on product and sold by a given sales person..."); log.info("Criteria query against Order with a subquery for line items with a subquery on product and sold by a given sales person...");
session.enableFilter("region").setParameter("region", "APAC"); session.enableFilter("region").setParameter("region", "APAC");
DetachedCriteria lineItemSubquery = DetachedCriteria.forClass(LineItem.class) Subquery<LineItem> lineItemSubquery = detachedCriteriaBuilder.createQuery().subquery( LineItem.class );
.add( Restrictions.ge( "quantity", 1L ) ) Root<LineItem> itemRoot = lineItemSubquery.from( LineItem.class );
.createCriteria( "product" ) Join<Object, Object> product = itemRoot.join( "product", JoinType.INNER );
.add( Restrictions.eq( "name", "Acme Hair Gel" ) ) lineItemSubquery.where(
.setProjection( Property.forName( "id" ) ); detachedCriteriaBuilder.and(
detachedCriteriaBuilder.ge( itemRoot.get( "quantity" ), 1L ),
detachedCriteriaBuilder.equal( product.get( "name" ), "Acme Hair Gel" )
)
);
lineItemSubquery.select( product.get( "id" ) );
// DetachedCriteria lineItemSubquery = DetachedCriteria.forClass(LineItem.class)
// .add( Restrictions.ge( "quantity", 1L ) )
// .createCriteria( "product" )
// .add( Restrictions.eq( "name", "Acme Hair Gel" ) )
// .setProjection( Property.forName( "id" ) );
List orders = session.createCriteria(Order.class) CriteriaQuery<Order> orderCriteria = criteriaBuilder.createQuery( Order.class );
.add(Subqueries.exists(lineItemSubquery)) Root<Order> orderRoot = orderCriteria.from( Order.class );
.add(Restrictions.eq("buyer", "gavin")) orderCriteria.where(
.list(); criteriaBuilder.and(
criteriaBuilder.exists( lineItemSubquery ),
criteriaBuilder.equal( orderRoot.get( "buyer"),"gavin" )
)
);
List<Order> orders = session.createQuery( orderCriteria ).list();
// List orders = session.createCriteria(Order.class)
// .add(Subqueries.exists(lineItemSubquery))
// .add(Restrictions.eq("buyer", "gavin"))
// .list();
assertEquals("Incorrect orders count", 1, orders.size()); assertEquals("Incorrect orders count", 1, orders.size());
@ -336,20 +401,45 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("region").setParameter("region", "APAC"); session.enableFilter("region").setParameter("region", "APAC");
session.enableFilter("effectiveDate").setParameter("asOfDate", testData.lastMonth.getTime()); session.enableFilter("effectiveDate").setParameter("asOfDate", testData.lastMonth.getTime());
DetachedCriteria productSubquery = DetachedCriteria.forClass(Product.class) Subquery<Product> productSubquery = detachedCriteriaBuilder.createQuery().subquery( Product.class );
.add(Restrictions.eq("name", "Acme Hair Gel")) Root<Product> productRoot = productSubquery.from( Product.class );
.setProjection(Property.forName("id")); productSubquery.select( productRoot.get( "id" ) );
productSubquery.where( detachedCriteriaBuilder.equal( productRoot.get( "name" ), "Acme Hair Gel" ) );
// DetachedCriteria productSubquery = DetachedCriteria.forClass(Product.class)
// .add(Restrictions.eq("name", "Acme Hair Gel"))
// .setProjection(Property.forName("id"));
lineItemSubquery = DetachedCriteria.forClass(LineItem.class) lineItemSubquery = detachedCriteriaBuilder.createQuery().subquery( LineItem.class );
.add(Restrictions.ge("quantity", 1L )) itemRoot = lineItemSubquery.from( LineItem.class );
.createCriteria("product") product = itemRoot.join( "product", JoinType.INNER );
.add(Subqueries.propertyIn("id", productSubquery)) lineItemSubquery.where(
.setProjection(Property.forName("id")); detachedCriteriaBuilder.and(
detachedCriteriaBuilder.ge( itemRoot.get( "quantity" ), 1L ),
detachedCriteriaBuilder.in( product.get( "id" ) ).value( productSubquery )
)
);
lineItemSubquery.select( product.get( "id" ) );
orders = session.createCriteria(Order.class) orderCriteria = criteriaBuilder.createQuery( Order.class );
.add(Subqueries.exists(lineItemSubquery)) orderRoot = orderCriteria.from( Order.class );
.add(Restrictions.eq("buyer", "gavin")) orderCriteria.where(
.list(); criteriaBuilder.and(
criteriaBuilder.exists( lineItemSubquery ),
criteriaBuilder.equal( orderRoot.get( "buyer" ), "gavin" )
)
);
orders = session.createQuery( orderCriteria ).list();
// lineItemSubquery = DetachedCriteria.forClass(LineItem.class)
// .add(Restrictions.ge("quantity", 1L ))
// .createCriteria("product")
// .add(Subqueries.propertyIn("id", productSubquery))
// .setProjection(Property.forName("id"));
//
// orders = session.createCriteria(Order.class)
// .add(Subqueries.exists(lineItemSubquery))
// .add(Restrictions.eq("buyer", "gavin"))
// .list();
assertEquals("Incorrect orders count", 1, orders.size()); assertEquals("Incorrect orders count", 1, orders.size());
@ -358,10 +448,20 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("region").setParameter("region", "APAC"); session.enableFilter("region").setParameter("region", "APAC");
session.enableFilter("effectiveDate").setParameter("asOfDate", testData.fourMonthsAgo.getTime()); session.enableFilter("effectiveDate").setParameter("asOfDate", testData.fourMonthsAgo.getTime());
orders = session.createCriteria(Order.class) orderCriteria = criteriaBuilder.createQuery( Order.class );
.add(Subqueries.exists(lineItemSubquery)) orderRoot = orderCriteria.from( Order.class );
.add(Restrictions.eq("buyer", "gavin")) orderCriteria.where(
.list(); criteriaBuilder.and(
criteriaBuilder.exists( lineItemSubquery ),
criteriaBuilder.equal( orderRoot.get( "buyer" ), "gavin" )
)
);
orders = session.createQuery( orderCriteria ).list();
// orders = session.createCriteria(Order.class)
// .add(Subqueries.exists(lineItemSubquery))
// .add(Restrictions.eq("buyer", "gavin"))
// .list();
assertEquals("Incorrect orders count", 0, orders.size()); assertEquals("Incorrect orders count", 0, orders.size());
@ -400,7 +500,7 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("region").setParameter( "region", "APAC" ); session.enableFilter("region").setParameter( "region", "APAC" );
List orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li, Product as p where p.id = li.product and li.quantity >= ?1 and p.name = ?2) and o.buyer = ?3") List orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li, Product as p where p.id = li.product and li.quantity >= ?1 and p.name = ?2) and o.buyer = ?3")
.setParameter(1, 1L).setParameter(2, "Acme Hair Gel").setString(3, "gavin").list(); .setParameter(1, 1L).setParameter(2, "Acme Hair Gel").setParameter(3, "gavin").list();
assertEquals( "Incorrect orders count", 1, orders.size() ); assertEquals( "Incorrect orders count", 1, orders.size() );
@ -410,7 +510,7 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("effectiveDate").setParameter( "asOfDate", testData.lastMonth.getTime() ); session.enableFilter("effectiveDate").setParameter( "asOfDate", testData.lastMonth.getTime() );
orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li where li.quantity >= ?1 and li.product in (select p.id from Product p where p.name = ?2)) and o.buyer = ?3") orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li where li.quantity >= ?1 and li.product in (select p.id from Product p where p.name = ?2)) and o.buyer = ?3")
.setParameter(1, 1L).setString(2, "Acme Hair Gel").setString(3, "gavin").list(); .setParameter(1, 1L).setParameter(2, "Acme Hair Gel").setParameter(3, "gavin").list();
assertEquals( "Incorrect orders count", 1, orders.size() ); assertEquals( "Incorrect orders count", 1, orders.size() );
@ -433,7 +533,7 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("effectiveDate").setParameter("asOfDate", testData.lastMonth.getTime()); session.enableFilter("effectiveDate").setParameter("asOfDate", testData.lastMonth.getTime());
orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li where li.quantity >= ?1 and li.product in (select p.id from Product p where p.name = ?2)) and o.buyer = ?3") orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li where li.quantity >= ?1 and li.product in (select p.id from Product p where p.name = ?2)) and o.buyer = ?3")
.setParameter(1, 1L).setParameter(2, "Acme Hair Gel").setString(3, "gavin").list(); .setParameter(1, 1L).setParameter(2, "Acme Hair Gel").setParameter(3, "gavin").list();
assertEquals("Incorrect orders count", 1, orders.size()); assertEquals("Incorrect orders count", 1, orders.size());
@ -443,7 +543,7 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
session.enableFilter("effectiveDate").setParameter("asOfDate", testData.lastMonth.getTime()); session.enableFilter("effectiveDate").setParameter("asOfDate", testData.lastMonth.getTime());
orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li where li.quantity >= ?1 and li.product in (select p.id from Product p where p.name = ?2)) and o.buyer = ?3") orders = session.createQuery("select o from Order as o where exists (select li.id from LineItem li where li.quantity >= ?1 and li.product in (select p.id from Product p where p.name = ?2)) and o.buyer = ?3")
.setParameter(1, 1L).setString(2, "Acme Hair Gel").setString(3, "gavin").list(); .setParameter(1, 1L).setParameter(2, "Acme Hair Gel").setParameter(3, "gavin").list();
assertEquals("Incorrect orders count", 1, orders.size()); assertEquals("Incorrect orders count", 1, orders.size());
@ -652,11 +752,20 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
Session session = openSession(); Session session = openSession();
session.enableFilter( "effectiveDate" ).setParameter( "asOfDate", new Date() ); session.enableFilter( "effectiveDate" ).setParameter( "asOfDate", new Date() );
Product prod = ( Product ) session.createCriteria( Product.class ) CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
CriteriaQuery<Product> criteria = criteriaBuilder.createQuery( Product.class );
Root<Product> root = criteria.from( Product.class );
criteria.where( criteriaBuilder.equal( root.get( "id" ), testData.prod1Id ) );
Product prod = session.createQuery( criteria )
.setResultTransformer( DistinctRootEntityResultTransformer.INSTANCE ) .setResultTransformer( DistinctRootEntityResultTransformer.INSTANCE )
.add( Restrictions.eq( "id", testData.prod1Id ) )
.uniqueResult(); .uniqueResult();
// Product prod = ( Product ) session.createCriteria( Product.class )
// .setResultTransformer( DistinctRootEntityResultTransformer.INSTANCE )
// .add( Restrictions.eq( "id", testData.prod1Id ) )
// .uniqueResult();
assertNotNull( prod ); assertNotNull( prod );
assertEquals( "Incorrect Product.categories count for filter", 1, prod.getCategories().size() ); assertEquals( "Incorrect Product.categories count for filter", 1, prod.getCategories().size() );
@ -798,11 +907,18 @@ public class DynamicFilterTest extends BaseNonConfigCoreFunctionalTestCase {
Session session = openSession(); Session session = openSession();
List result = session.createCriteria( Product.class ) CriteriaBuilder criteriaBuilder = session.getCriteriaBuilder();
.add( Restrictions.eq( "id", testData.prod1Id ) ) CriteriaQuery<Product> criteria = criteriaBuilder.createQuery( Product.class );
.list(); Root<Product> root = criteria.from( Product.class );
criteria.where( criteriaBuilder.equal(root.get( "id" ), testData.prod1Id ) );
Product prod = ( Product ) result.get( 0 ); List<Product> result = session.createQuery( criteria ).list();
// List result = session.createCriteria( Product.class )
// .add( Restrictions.eq( "id", testData.prod1Id ) )
// .list();
Product prod = result.get( 0 );
long initLoadCount = sessionFactory().getStatistics().getCollectionLoadCount(); long initLoadCount = sessionFactory().getStatistics().getCollectionLoadCount();
long initFetchCount = sessionFactory().getStatistics().getCollectionFetchCount(); long initFetchCount = sessionFactory().getStatistics().getCollectionFetchCount();