Hibernate学习15(HQL查询)

2017-08-11  本文已影响0人  又是那一片天
Hibernate查询方式:
HQL检索有如下功能:
Hibernate基本逻辑代码
    public static void test() {
        StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build();// 配置文件configure()
        SessionFactory sessionFactory = new MetadataSources(registry).buildMetadata().buildSessionFactory();
        Session session = sessionFactory.openSession();
        Transaction transaction = session.beginTransaction();
        //这里写查询方法
        test(session);

        transaction.commit();
        session.close();
        sessionFactory.close();
    }
查询的持久化对象和表
//员工
public class Employee {
    
    private Integer id;
    private String name;
    private float salary;
    private String email;
    private Department dept;

    public Employee() {
        super();
    }
    public Employee(String name, String email) {
        super();
        this.name = name;
        this.email = email;
    }
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public float getSalary() {
        return salary;
    }
    public void setSalary(float salary) {
        this.salary = salary;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    public Department getDept() {
        return dept;
    }
    public void setDept(Department dept) {
        this.dept = dept;
    }
    @Override
    public String toString() {
        return "Employee [id=" + id + ", name=" + name + ", salary=" + salary + ", email=" + email + ", dept=" + dept
                + "]";
    }
    
    

}
//部门
public class Department {
    private Integer id;
    private String name;
    private Set<Employee> employees=new HashSet<>();
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Set<Employee> getEmployees() {
        return employees;
    }
    public void setEmployees(Set<Employee> employees) {
        this.employees = employees;
    }
    @Override
    public String toString() {
        return "Department [id=" + id + ", name=" + name + ", employees=" + employees + "]";
    }
    
    
    
}

此处省略映射文件(一对多关系)

部门表 员表
HQL检索步骤
    /**
     * 第一次查询
     */
    public static void queryA(Session session) {
        // 1.创建Query对象
        String hql = "FROM Employee e WHERE e.salary > ? AND e.email LIKE ? ";
        Query query = session.createQuery(hql);
        // 2.绑定参数
        query.setParameter(0, 5255.4f).setParameter(1, "%%");
        // 3.执行查询
        List<Employee> eList = query.list();
        System.out.println(eList.size());
    }
HQL可以直接使用持久化类的类名 和属性名
命名参数:取代"?"为查询条件命名
    /**
     * 命名参数
     * */
    public static void queryB(Session session) {
        // 1.创建Query对象
        String hql = "FROM Employee e WHERE e.salary > :salary AND e.email LIKE :email ";
        Query query = session.createQuery(hql);
        // 2.绑定参数
        query.setParameter("salary", 5255.4f).setParameter("email", "%%");
        // 3.执行查询
        List<Employee> eList = query.list();
        System.out.println(eList.size());
    }
实体参数 :HQL是面向对象的
    /**
     * 实体参数
     * */
    public static void queryC(Session session) {
        // 1.创建Query对象
        String hql = "FROM Employee e WHERE e.salary > ? AND e.dept = ? ";
        Query query = session.createQuery(hql);
        // 2.绑定参数
        Department e=new Department();
        e.setId(1);
        query.setParameter(0, 5255.4f).setParameter(1, e);
        // 3.执行查询
        List<Employee> eList = query.list();
        System.out.println(eList.size());
    }
ORDER BY 排序
    /**
     * ORDER BY 排序
     * */
    public static void queryD(Session session) {
        // 1.创建Query对象
        String hql = "FROM Employee e WHERE  e.dept = ? ORDER BY  e.salary DESC";
        Query query = session.createQuery(hql);
        // 2.绑定参数
        Department e=new Department();
        e.setId(1);
        query.setParameter(0, e);
        // 3.执行查询
        List<Employee> eList = query.list();
        for (Employee employee : eList) {
            System.out.println(employee.getName());
        }
    }
分页查询
    /**
     * 分页查询
     * */
    public static void queryF(Session session) {
        String hql = "FROM Employee e  WHERE e.id > ?";
        Query query = session.createQuery(hql);
        query.setParameter(0, 3);
        int pageNo=0;//分页起始位置包涵
        int pageSize=2;//每页长度
        List<Employee> eList = query.setFirstResult(pageNo).setMaxResults(pageSize).list();
        for (Employee employee : eList) {
            System.out.println(employee.getName());
        }
    }
命名查询 hql放在映射文件中

在映射文件中hibernate-mapping元素下

 <query name="salaryEmps"><![CDATA[FROM Employee e WHERE e.salary > :minSal AND e.salary < :maxSal]]></query>
    /**
     * 命名查询 hql放在映射文件中
     * */
    public static void queryG(Session session) {
        String hql = "FROM Employee e  WHERE e.id > ?";
        Query query = session.getNamedQuery("salaryEmps");
        query.setParameter("minSal", 5000f);
        query.setParameter("maxSal", 20000f);
        List<Employee> eList = query.list();
        for (Employee employee : eList) {
            System.out.println(employee.getName());
        }
    }
投影查询 查询部分属性 默认返回数组

返回数组

    /**
     * 投影查询 查询部分属性 默认返回数组
     * */
    public static void queryH(Session session) {
        String hql = "SELECT e.email, e.name FROM Employee e WHERE e.dept = :dept";
        Query query = session.createQuery(hql);
        Department e=new Department();
        e.setId(1);
        query.setParameter("dept", e);
        List<Object[]> eList = query.list();
        for (Object[] os : eList) {
            System.out.println(Arrays.asList(os));
        }
    }

返回对象

    /**
     * 投影查询 查询部分属性 默认返回数组
     * */
    public static void queryH(Session session) {
        String hql = "SELECT e.email, e.name FROM Employee e WHERE e.dept = :dept";
        Query query = session.createQuery(hql);
        Department e=new Department();
        e.setId(1);
        query.setParameter("dept", e);
        List<Object[]> eList = query.list();
        for (Object[] os : eList) {
            System.out.println(Arrays.asList(os));
        }
    }
报表查询 使用函数
    /**
     * 报表查询
     * */
    public static void queryJ(Session session) {
        //持久化类提供这样的构造器
        String hql = "SELECT min(e.salary), max(e.salary)  FROM Employee e  GROUP BY e.dept HAVING min(salary)> :minsal";
        Query query = session.createQuery(hql);
        query.setParameter("minsal", 1000f);
        List<Object[]> eList = query.list();
        for (Object[] os : eList) {
            System.out.println(Arrays.asList(os));
        }
    }
本地sql:可以执行sql所有操作
    /**
     * 本地sql
     * 可以执行sql所有操作
     * */
    public static void queryL(Session session) {
        String sql = "INSERT INTO department  (name) VALUES(:name)";
        Query query = session.createNativeQuery(sql);//使用createNativeQuery方法
        query.setParameter("name", "本地sql").executeUpdate();
    }
上一篇 下一篇

猜你喜欢

热点阅读