1, Object navigation query
Previous relationships between customers and contacts were one to many: One to many
Scenario: query the customer according to the customer id, and find out all contacts of the customer
@Test public void selectTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Find out the customer according to C ﹣ ID Customer customer = session.get(Customer.class,1); //Then find out the contact person of the customer Set<Salesperson> set = customer.getSalespersonSet(); Iterator<Salesperson> it = set.iterator(); while (it.hasNext()) { Salesperson str = it.next(); System.out.println(str.getS_name()); } transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/42e4e/42e4ebbdd48137c93dc42bb7224fc157d018a3c1" alt=""
2, HQL query
- Query all customer information
- Create Query object and write out hql statement
- Call the method in the query object to get the result
- Query all from + entity class names
@Test public void selectTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Create query object Query query = session.createQuery("from Customer"); //Call method to get result List<Customer> list = query.list(); for (Customer customer: list) { System.out.println(customer.getC_id()+"-"+customer.getC_name()); } transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/1be9a/1be9a02689ad3ff06d3bd42978a3c0ec7c7584e6" alt=""
- Condition query
- Statement: from entity class name where entity class property =? and entity class name
@Test public void selectByCidAndCnameTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Create query object Query query = session.createQuery("from Customer where c_id = ? and c_name = ?"); query.setParameter(0,1); query.setParameter(1,"Li customer"); //Call method to get result List<Customer> list = query.list(); for (Customer customer: list) { System.out.println(customer.getC_id()+"-"+customer.getC_name()); } transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/d7b2f/d7b2fb335327aa5492f9df46cc64c9cd8542c1a7" alt=""
Condition query
- Sort query
- Statement: from entity class name order by entity class name asc/desc
@Test public void selectOrderByTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Create query object Query query = session.createQuery("from Customer order by c_id desc "); //Call method to get result List<Customer> list = query.list(); for (Customer customer: list) { System.out.println(customer.getC_id()+"-"+customer.getC_name()); } transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/972ab/972abaaae4c541539d270c404404e70c78685d99" alt=""
- Paging query
@Test public void selectLimitTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Create query object Query query = session.createQuery("from Customer"); //Set paging data query.setFirstResult(0); query.setMaxResults(2); //Call method to get result List<Customer> list = query.list(); for (Customer customer: list) { System.out.println(customer.getC_id()+"-"+customer.getC_name()); } transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/904e9/904e9766d68e04b130cc3ce089427779ac58a0e1" alt=""
- Projection query
- Statement: select * from entity class attribute name 1, entity class attribute name 2, from entity class name
- Cannot write * after select, not supported
@Test public void selectSomeTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Create query object Query query = session.createQuery("select c_name from Customer"); //Call method to get result List<Object> lists = query.list(); for (Object list: lists) { System.out.println(list); } transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/4601b/4601b365071c50602ec652dd8c300fa3ae18e8f7" alt=""
image.png
- Aggregate function use
- count ,sum , avg , mac , min
- Statement: select count (*) from entity class name
@Test public void selectHanshuTest(){ SessionFactory sessionFactory = null; Session session = null; Transaction transaction = null; try{ sessionFactory = HibernateUtils.getSessionFactory(); session = sessionFactory.openSession(); transaction = session.beginTransaction(); //Create query object Query query = session.createQuery("select count(*) from Customer"); //Call method to get result Object count = query.uniqueResult(); //Convert to long, then int Long co = Long.parseLong(count.toString()); System.out.println(co.intValue()); transaction.commit(); }catch (Exception e){ transaction.rollback(); e.printStackTrace(); }finally{ session.close(); sessionFactory.close(); } }
data:image/s3,"s3://crabby-images/37e11/37e11470da44662d3692b403c0ad7fa9b212c615" alt=""