本文整理匯總了Java中com.mysema.query.jpa.hibernate.HibernateQuery類的典型用法代碼示例。如果您正苦於以下問題:Java HibernateQuery類的具體用法?Java HibernateQuery怎麽用?Java HibernateQuery使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
HibernateQuery類屬於com.mysema.query.jpa.hibernate包,在下文中一共展示了HibernateQuery類的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: findAll
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Override
public Page<T> findAll(final Predicate predicate, final Pageable pageable, final Sort... sorts) {
return hibernateTemplate.executeWithNativeSession(new HibernateCallback<Page<T>>() {
public Page<T> doInHibernate(Session session) throws HibernateException, SQLException {
HibernateQuery query = new HibernateQuery(session).from(metamodel);
applyWhere(query, predicate);
applySorting(query, sorts);
applyPagination(query, pageable);
List<T> content = query.list(metamodel);
HibernateQuery countQuery = new HibernateQuery(session).from(metamodel);
applyWhere(countQuery, predicate);
long total = countQuery.count();
return new Pagination<T>(content, pageable, total);
}
});
}
示例2: groupingTest
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
public void groupingTest() {
HibernateQuery query = new HibernateQuery(getCurrentSession());
QEmployee employee = QEmployee.employee;
QCompany company = QCompany.company;
List<Tuple> loaded =
query.from(employee)
.groupBy(employee.company.code, employee.empGrade.code)
.list(employee.company.code.as("CompanyCode"),
employee.empGrade.code.as("GradeCode"),
employee.countDistinct().as("RowCount"));
log.info("Group by = [{}]", loaded);
}
示例3: getHibernateQuery
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
@SuppressWarnings( "unchecked" )
public void getHibernateQuery() {
HibernateQuery query = new HibernateQuery(getCurrentSession());
QEmployee employee = QEmployee.employee;
org.hibernate.Query hibernateQuery =
query.from(employee)
.where(employee.name.like("Smith%"))
.createQuery(employee);
List<Employee> emps = hibernateQuery.list();
for (Employee emp : emps)
log.info("Employee=[{}]", emp);
}
示例4: count
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Override
public long count(final Predicate predicate) {
return hibernateTemplate.executeWithNativeSession(new HibernateCallback<Long>() {
public Long doInHibernate(Session session) throws HibernateException, SQLException {
HibernateQuery query = new HibernateQuery(session).from(metamodel);
applyWhere(query, predicate);
return query.count();
}
});
}
示例5: getCompany
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
/**
* Gets company.
*
* @return the company
*/
public static Company getCompany() {
HibernateQuery query = new HibernateQuery(UnitOfWorks.getCurrentSession());
QCompany company = QCompany.company;
return query
.from(company)
.where(company.code.eq(getCompanyCode()))
.singleResult(company);
// return (Company) UnitOfWorks.getCurrentSession()
// .createCriteria(Company.class)
// .add(Restrictions.eq("code", getCompanyCode()))
// .uniqueResult();
}
示例6: getDepartment
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
/**
* Gets department.
*
* @return the department
*/
public static Department getDepartment() {
HibernateQuery query = new HibernateQuery(UnitOfWorks.getCurrentSession());
QDepartment department = QDepartment.department;
return query.from(department)
.where(department.code.eq(getDepartmentCode()))
.singleResult(department);
// return (Department) UnitOfWorks.getCurrentSession()
// .createCriteria(Department.class)
// .add(Restrictions.eq("code", getDepartmentCode()))
// .uniqueResult();
}
示例7: getUser
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
/**
* Gets user.
*
* @return the user
*/
public static User getUser() {
HibernateQuery query = new HibernateQuery(UnitOfWorks.getCurrentSession());
QUser user = QUser.user;
return query.from(user)
.where(user.username.eq(getUsername()))
.singleResult(user);
// return (User) UnitOfWorks.getCurrentSession()
// .createCriteria(User.class)
// .add(Restrictions.eq("username", getUsername()))
// .uniqueResult();
}
示例8: simpleWhere
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
public void simpleWhere() {
HibernateQuery query = new HibernateQuery(getCurrentSession());
QEmployee employee = QEmployee.employee;
Employee loaded = query.from(employee)
.where(employee.name.eq("Smith"))
.uniqueResult(employee);
log.info("Employee=[{}]", loaded);
}
示例9: joinWhere
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
public void joinWhere() {
HibernateQuery query = new HibernateQuery(getCurrentSession());
QEmployee employee = QEmployee.employee;
QCompany company = QCompany.company;
Employee loaded = query.from(employee)
.innerJoin(employee.company, company)
.where(employee.name.eq("Smith").and(company.code.eq("KTH")))
.uniqueResult(employee);
log.info("Employee=[{}]", loaded);
}
示例10: subQueriesTest
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
public void subQueriesTest() {
QDepartment department = QDepartment.department;
QDepartmentMember member = QDepartmentMember.departmentMember;
QDepartment d = new QDepartment("d");
HibernateQuery query = new HibernateQuery(getCurrentSession());
QEmployee employee = QEmployee.employee;
QEmployee e = new QEmployee("e");
query.from(employee)
.where(employee.age.gt(new HibernateSubQuery().from(e).unique(e.age.avg())))
.list(employee);
// 직원이 가장 많은 부서 (이것은 차라리 subquery 보다 이 방식이 낫다)
List<Long> results = query.from(member).groupBy(member.department).list(member.count());
if (results != null && results.size() > 0) {
Long max = (Long) results.get(0);
List<Department> bigDepartment =
query.from(department)
.where(department.members.size().eq(max.intValue()))
.list(department);
}
}
示例11: transformTest
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
public void transformTest() {
QCompany company = QCompany.company;
QEmployee employee = QEmployee.employee;
HibernateQuery query = new HibernateQuery(getCurrentSession());
Map<Long, List<Employee>> results =
query.from(company)
.innerJoin(company.employees, employee)
.transform(groupBy(company.id).as(list(employee)));
}
示例12: queryCompany
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
@Test
@Transactional( readOnly = true )
public void queryCompany() {
QCompany qCompany = QCompany.company;
HibernateQuery query = new HibernateQuery(getCurrentSession());
List<Company> loaded = query.from(qCompany)
.where(qCompany.active.isTrue().and(qCompany.name.isNotEmpty()).and(qCompany.code.in("KTH", "KT")))
.list(qCompany);
log.debug("company={}", StringTool.listToString(loaded));
}
示例13: createQuery
import com.mysema.query.jpa.hibernate.HibernateQuery; //導入依賴的package包/類
private HibernateQuery createQuery() {
return new HibernateQuery(sessionFactory.getCurrentSession());
}