Java框架之Hibernate实战篇2

1.cn.itcast.entity包里面:

(1)Customer.java

复制代码
package cn.itcast.entity;

import java.util.HashSet;
import java.util.Set;

public class Customer {
// 用户id
private Integer cid;

// 用户名称
private String custName;

// 用户级别
private String custLevel;

// 用户来源
private String custSource;

// 联系电话
private String custPhone;

// 手机
private String custMobile;

// 在客户实体类里面表示多个联系人,一个客户有多个联系人
// hibernate要求使用集合表示多的数据,使用set集合:
// import java.util.HashSet;import java.util.Set;
private Set<LinkMan> setLinkMan = new HashSet<LinkMan>();

public Set<LinkMan> getSetLinkMan() {
    return setLinkMan;
}

public void setSetLinkMan(Set<LinkMan> setLinkMan) {
    this.setLinkMan = setLinkMan;
}

public Integer getCid() {
    return cid;
}

public void setCid(Integer cid) {
    this.cid = cid;
}

public String getCustName() {
    return custName;
}

public void setCustName(String custName) {
    this.custName = custName;
}

public String getCustLevel() {
    return custLevel;
}

public void setCustLevel(String custLevel) {
    this.custLevel = custLevel;
}

public String getCustSource() {
    return custSource;
}

public void setCustSource(String custSource) {
    this.custSource = custSource;
}

public String getCustPhone() {
    return custPhone;
}

public void setCustPhone(String custPhone) {
    this.custPhone = custPhone;
}

public String getCustMobile() {
    return custMobile;
}

public void setCustMobile(String custMobile) {
    this.custMobile = custMobile;
}

}
复制代码
Customer.hbm.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?> 复制代码 (2)LinkMan.java

复制代码
package cn.itcast.entity;

public class LinkMan {
// 联系人编号(主键)
private Integer lkm_id;

// 联系人姓名
private String lkm_name;

// 联系人性别
private String lmk_gender;

// 联系人办公电话
private String lkm_phone;

// 在联系人实体类里面表示所有客户,一个联系人只能属于一个客户
// Customer customer=new Customer();
private Customer customer;

public Customer getCustomer() {
    return customer;
}

public void setCustomer(Customer customer) {
    this.customer = customer;
}

public Integer getLkm_id() {
    return lkm_id;
}

public void setLkm_id(Integer lkm_id) {
    this.lkm_id = lkm_id;
}

public String getLkm_name() {
    return lkm_name;
}

public void setLkm_name(String lkm_name) {
    this.lkm_name = lkm_name;
}

public String getLmk_gender() {
    return lmk_gender;
}

public void setLmk_gender(String lmk_gender) {
    this.lmk_gender = lmk_gender;
}

public String getLkm_phone() {
    return lkm_phone;
}

public void setLkm_phone(String lkm_phone) {
    this.lkm_phone = lkm_phone;
}

}
复制代码
LinkMan.hbm.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?>
<many-to-one name="customer" class="cn.itcast.entity.Customer" column="clid"></many-to-one>
复制代码 2.HibernateUtils包里面的HibernateUtils.java工具类,添加本地线程绑定的session的方法

复制代码
package cn.itcast.utils;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtils {

// 加载核心配置文件,静态代码块实现
static Configuration cfg = null;

static SessionFactory sessionFactory = null;
static {
    cfg = new Configuration();
    cfg.configure();
    sessionFactory = cfg.buildSessionFactory();
}

// 提供返回与本地线程绑定的session的方法
public static Session getSessionObject() {
    return sessionFactory.getCurrentSession();
}

// 提供方法返回sessionFactory
public static SessionFactory getSessionFactory() {
    return sessionFactory;
}

public static void main(String[] args) {

}

}
复制代码
3.Hibernate核心配置文件

复制代码

<?xml version="1.0" encoding="UTF-8"?> com.mysql.jdbc.Driver jdbc:mysql:///hibernate_test3 root root true true update org.hibernate.dialect.MySQLDialect thread 复制代码 4.Hibernatetest包

(1)HibernateOnetoMany.java

复制代码
package hibernatetest;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.junit.Test;

import cn.itcast.entity.Customer;
import cn.itcast.entity.LinkMan;
import cn.itcast.utils.HibernateUtils;

public class HibernateOnetoMany {

// 演示:一对多级联保存
@Test
public void testUpdate() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 添加一个客户,为这个客户添加一个联系人
        // 1 创建客户和联系人对象
        Customer customer = new Customer();
        customer.setCustLevel("vip");
        customer.setCustMobile("8888");
        customer.setCustName("橡果国际");
        customer.setCustPhone("18345782345");
        customer.setCustSource("上海");

        LinkMan linkman = new LinkMan();
        linkman.setLkm_name("王小卓");
        linkman.setLkm_phone("173456379876");
        linkman.setLmk_gender("女");

        // 2 在客户表示所有联系人,在联系人表示客户
        // 建立客户对象和联系人对象关系
        // 2.1 把联系人对象 放到客户对象的set集合里面
        customer.getSetLinkMan().add(linkman);
        // 2.2 把客户对象放到联系人里面
        linkman.setCustomer(customer);

        // 3 保存到数据库
        session.save(customer);
        session.save(linkman);

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }
}

// 演示:一对多级联保存
@Test
public void testAddDemo2() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        Customer customer = new Customer();
        customer.setCustLevel("普通");
        customer.setCustName("奥克斯");
        customer.setCustPhone("18932222237");
        customer.setCustSource("北京");

        LinkMan linkman = new LinkMan();
        linkman.setLkm_name("陈小桥");
        linkman.setLkm_phone("15024324567");
        linkman.setLmk_gender("女");

        customer.getSetLinkMan().add(linkman);
        // 少了这句,linkman.setCustomer(customer);只执行t_customer表的insert语句
        // 添加它和session.save(linkman);,则t_linkman表中添加的新数据(陈小桥)才会加进去
        linkman.setCustomer(customer);

        // save() 保存要有哦!
        session.save(customer);
        session.save(linkman);

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        // sessionFactory.close();
        // session.close();
    }
}

// 演示:一对多级联删除
@Test
public void testDeleteDemo() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.根据id查询客户对象
        Customer customer = session.get(Customer.class, 12);
        // 2.调用删除方法
        session.delete(customer);
        // 3.提交事务
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        // sessionFactory.close();
    }
}

// 演示:一对多修改
@Test
public void testUpdateDemo() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();
        // 1.根据id查询联系人,根据id查询客户
        Customer customer1 = session.get(Customer.class, 3);
        LinkMan linkman1 = session.get(LinkMan.class, 1);
        // 2.设置持久态对象值
        // i.把联系人放到客户里面
        customer1.getSetLinkMan().add(linkman1);
        // ii.把客户放到联系人里面
        linkman1.setCustomer(customer1);
        // 3.提交事务
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        // sessionFactory.close();
    }

}

}
复制代码
(2)HibernateManytoMany.java

复制代码
package hibernatetest;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.junit.Test;

import cn.itcast.manytomany.Role;
import cn.itcast.manytomany.User;
import cn.itcast.utils.HibernateUtils;

public class HibernateManytoMany {
// 演示维护第三张表
@Test
public void testTable1() {
SessionFactory sessionFactory = null;
Session session = null;
Transaction tx = null;
try {
sessionFactory = HibernateUtils.getSessionFactory();
session = sessionFactory.openSession();
tx = session.beginTransaction();

        // 让某个用户拥有某个角色
        // 1.查询
        User user1 = session.get(User.class, 2);
        Role role1 = session.get(Role.class, 2);
        // 2.放
        user1.getSetRole().add(role1);

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        // sessionFactory.close();
    }
}

// 演示:维护第三张表
@Test
public void testTable2() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 让某个用户没有某个角色
        User user2 = session.get(User.class, 2);
        Role role2 = session.get(Role.class, 3);

        // 从用户里面把角色去掉
        user2.getSetRole().remove(role2);
        // 提交事务
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        // sessionFactory.close();
    }

}

// 演示:多对多级联删除
@Test
public void testSave() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 添加两个用户,为每个用户相加两个角色
        // 1.创建对象
        User user3 = new User();
        user3.setUser_name("春花");
        user3.setUser_password("8766899");

        User user4 = new User();
        user4.setUser_name("mary");
        user4.setUser_password("456");

        Role role3 = new Role();
        role3.setRole_name("pig");
        role3.setRole_memo("粉色的");

        Role role4 = new Role();
        role4.setRole_name("秘书");
        role4.setRole_memo("秘书");

        Role role5 = new Role();
        role5.setRole_name("保安");
        role5.setRole_memo("保安");

        // 2.建立关系,把角色放到用户里面
        user3.getSetRole().add(role3);
        user3.getSetRole().add(role4);

        user4.getSetRole().add(role4);
        user4.getSetRole().add(role5);

        // 3.保存
        session.save(user3);
        session.save(user4);

        // 4.提交事务
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        // sessionFactory.close();
    }
}

// 演示:多对多级联保存
@Test
public void testDelete() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        User user5 = session.get(User.class, 1);
        session.delete(user5);
        // 提交事务
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        // sessionFactory.close();
    }
}

}
复制代码
5.cn.itcast.manytomany包

(1)Role.java

复制代码
package cn.itcast.manytomany;

import java.util.HashSet;
import java.util.Set;

public class Role {

private Integer role_id;

private String role_name;

private String role_memo;

// 一个角色有多个客户
private Set<User> setUser = new HashSet<User>();

public Set<User> getSetUser() {
    return setUser;
}

public void setSetUser(Set<User> setUser) {
    this.setUser = setUser;
}

public Integer getRole_id() {
    return role_id;
}

public void setRole_id(Integer role_id) {
    this.role_id = role_id;
}

public String getRole_name() {
    return role_name;
}

public void setRole_name(String role_name) {
    this.role_name = role_name;
}

public String getRole_memo() {
    return role_memo;
}

public void setRole_memo(String role_memo) {
    this.role_memo = role_memo;
}

}
复制代码
Role.hbm.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?> 复制代码 (2)User.java

复制代码
package cn.itcast.manytomany;

import java.util.HashSet;
import java.util.Set;

public class User {

private Integer user_id;

private String user_name;

private String user_password;

// 一个用户可以有多个角色
private Set<Role> setRole = new HashSet<Role>();

public Set<Role> getSetRole() {
    return setRole;
}

public void setSetRole(Set<Role> setRole) {
    this.setRole = setRole;
}

public Integer getUser_id() {
    return user_id;
}

public void setUser_id(Integer user_id) {
    this.user_id = user_id;
}

public String getUser_name() {
    return user_name;
}

public void setUser_name(String user_name) {
    this.user_name = user_name;
}

public String getUser_password() {
    return user_password;
}

public void setUser_password(String user_password) {
    this.user_password = user_password;
}

}
复制代码
User.hbm.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?> 复制代码 第四篇:HQL、QBC 、查询、检索策略、批量抓取等 相关练习篇

1.cn.itcast.entity包

(1)Cutomer.java

复制代码
package cn.itcast.entity;

import java.util.HashSet;
import java.util.Set;

public class Customer {
private Integer cid;

private String custName;

private String custLevel;

private String custSource;

private String custPhone;

private String custMobile;

// 在客户实体类里面表示多个联系人,一个客户有多个联系人
private Set<LinkMan> setLinkMan = new HashSet<LinkMan>();

public Set<LinkMan> getSetLinkMan() {
    return setLinkMan;
}

public void setSetLinkMan(Set<LinkMan> setLinkMan) {
    this.setLinkMan = setLinkMan;
}

public Integer getCid() {
    return cid;
}

public void setCid(Integer cid) {
    this.cid = cid;
}

public String getCustName() {
    return custName;
}

public void setCustName(String custName) {
    this.custName = custName;
}

public String getCustLevel() {
    return custLevel;
}

public void setCustLevel(String custLevel) {
    this.custLevel = custLevel;
}

public String getCustSource() {
    return custSource;
}

public void setCustSource(String custSource) {
    this.custSource = custSource;
}

public String getCustPhone() {
    return custPhone;
}

public void setCustPhone(String custPhone) {
    this.custPhone = custPhone;
}

public String getCustMobile() {
    return custMobile;
}

public void setCustMobile(String custMobile) {
    this.custMobile = custMobile;
}

}
复制代码
Customer.hbm.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?>
<hibernate-mapping>
<class name="cn.itcast.entity.Customer" table="t_customer">
<id name="cid" column="cid">
<generator class="native"></generator>
</id>
<property name="custName" column="custName"></property>
<property name="custLevel" column="custLevel"></property>
<property name="custSource" column="custSource"></property>
<property name="custPhone" column="custPhone"></property>
<property name="custMobile" column="custMobile"></property>
<!-- 在客户映射文件中,表示所有联系人 
        使用set标签表示所有联系人
        set标签里面有name属性:
             属性值写在客户实体类里面表示联系人的set集合名称
             
         inverse属性默认值:false不放弃关系维护
                        true表示放弃关系维护
    -->
<set name="setLinkMan" batch-size="10">
<!-- 一对多建表,有外键
            hibernate机制:双向维护外键,在一和多那一方都配置外键    
            column属性值:外键名称
         -->
<key column="clid"></key>
<one-to-many class="cn.itcast.entity.LinkMan"/>
</set>
</class>
</hibernate-mapping>

复制代码
(2).LinkMan.java

复制代码
package cn.itcast.entity;

public class LinkMan {
private Integer lkm_id; // 联系人编号(主键)

private String lkm_name;// 联系人姓名

private String lkm_gender;// 联系人性别

private String lkm_phone;// 联系人办公电话

// 在联系人实体类中表示所属客户,一个联系人只能有一个客户
private Customer customer;

public Customer getCustomer() {
    return customer;
}

public void setCustomer(Customer customer) {
    this.customer = customer;
}

public Integer getLkm_id() {
    return lkm_id;
}

public void setLkm_id(Integer lkm_id) {
    this.lkm_id = lkm_id;
}

public String getLkm_name() {
    return lkm_name;
}

public void setLkm_name(String lkm_name) {
    this.lkm_name = lkm_name;
}

public String getLkm_gender() {
    return lkm_gender;
}

public void setLkm_gender(String lkm_gender) {
    this.lkm_gender = lkm_gender;
}

public String getLkm_phone() {
    return lkm_phone;
}

public void setLkm_phone(String lkm_phone) {
    this.lkm_phone = lkm_phone;
}

}
复制代码
LinkMan.hbm.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?>
<hibernate-mapping>
<class name="cn.itcast.entity.LinkMan" table="t_linkman">
<id name="lkm_id" column="lkm_id">
<generator class="native"></generator>
</id>
<property name="lkm_name" column="lkm_name"></property>
<property name="lkm_gender" column="lkm_gender"></property>
<property name="lkm_phone" column="lkm_phone"></property>

<!-- 表示联系人所属客户 
        name属性:因为在联系人实体类使用customer对象表示,写customer名称
        class属性:customer全路径
        column属性:外键名称
    -->
<many-to-one name="customer" class="cn.itcast.entity.Customer" column="clid"></many-to-one>
</class>
</hibernate-mapping>

复制代码
2.utils包(同上)

HibernateUtils.java

复制代码
package ustils;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtils {

static Configuration cfg = null;

static SessionFactory sessionFactory = null;
static {
    cfg = new Configuration();
    cfg.configure();
    sessionFactory = cfg.buildSessionFactory();
}

public static Session getSessionobject() {
    return sessionFactory.getCurrentSession();
}

public static SessionFactory getSessionFactory() {
    return sessionFactory;
}

public static void main(String[] args) {

}

}
复制代码
3.Hibernate核心配置文件

复制代码

<?xml version="1.0" encoding="UTF-8"?>
<hibernate-configuration>
<session-factory>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///hibernate_test4</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">root</property>

<property name="hibernate.show_sql">true</property>
<property name="hibernate.format_sql">true</property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="hibernate.current_session_context_class">thread</property>

<mapping resource="cn/itcast/entity/Customer.hbm.xml"/>
<mapping resource="cn/itcast/entity/LinkMan.hbm.xml"/>
</session-factory>
</hibernate-configuration>

复制代码
4.cn.itcast.hibernantetest包

(1)HibernateDemo.java

复制代码
package cn.itcast.hibernantetest;

import java.util.List;
import java.util.Set;

import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.junit.Test;

import cn.itcast.entity.Customer;
import cn.itcast.entity.LinkMan;
import ustils.HibernateUtils;

public class HibernateDemo {

// 演示对象导航查询
@Test
public void testSelect1() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;

    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.查询cid=1客户
        Customer customer = session.get(Customer.class, 1);
        // 2.再查询这个客户里面的所有联系人(此时,得到set集合,没有发送语句)
        Set<LinkMan> linkman = customer.getSetLinkMan();

        // 发送了语句
        System.out.println(linkman.size());

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }
}

// 演示检索策略
@Test
public void testSelect2() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;

    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 根据cid=1客户
        // 执行get方法之后是否发送sql语句
        // 调用get方法马上发送sql语句查询数据库
        // Customer customer = session.get(Customer.class, 1);
        // System.out.println(customer.getCid());
        /*
         * 1 调用load方法之后,不会马上发送sql语句 (1)返回对象里面只有 id值
         * 
         * 2 得到对象里面不是id的其他值时候才会发送语句
         */
        Customer customer = session.load(Customer.class, 1);
        System.out.println(customer.getCid());
        System.out.println(customer.getCustName());

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }
}

// 演示批量抓取
@Test
public void testSelect3() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;

    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 查询所有客户
        Criteria criteria = session.createCriteria(Customer.class);
        // 得到每个客户里面所有的联系人
        List<Customer> list = criteria.list();

        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
            // 每个客户里面的所有联系人
            Set<LinkMan> setlinkman = customer.getSetLinkMan();
            for (LinkMan linkMan : setlinkman) {
                System.out.println((linkMan.getLkm_id() + "::" + linkMan.getLkm_name()));
            }
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }
}

}
复制代码
(2)HibernateHQL.java

复制代码
package cn.itcast.hibernantetest;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.junit.Test;

import cn.itcast.entity.Customer;
import ustils.HibernateUtils;

public class HibernateHQL {

// 演示查询所有
@Test
public void testSelect1() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        Query query = session.createQuery("from Customer");
        // 2.调用方法得到结果
        List<Customer> list = query.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示条件查询
@Test
public void testSelect2() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        // SELECT *FROM t_customer WHERE cid=? AND custName=?
        Query query = session.createQuery("from Customer c where c.cid=? and c.custName=?");
        // 2.设置条件
        // 向?里面设置值
        // setParameter方法两个参数
        // 第一个参数:int类型是?位置,?位置从0开始
        // 第二个参数:具体参数值
        // 设置第一个?值
        query.setParameter(0, 1);
        // 设置第二个?值
        query.setParameter(1, "百度");
        // 3.调用方法得到结果
        List<Customer> list = query.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示条件查询-模糊查询
@Test
public void testSelect3() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        Query query = session.createQuery("from Customer c where c.custName like ?");
        // 2.设置?的值
        query.setParameter(0, "%蒂%");
        // 3.调用方法得到结果
        List<Customer> list = query.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:排序查询
@Test
public void testSelect4() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        Query query = session.createQuery("from Customer order by cid desc");
        // 2.调用方法得到结果
        List<Customer> list = query.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:分页查询
@Test
public void testSelect5() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        // 写查询所有的语句
        Query query = session.createQuery("from Customer");
        // 2.设置分页数据
        // 2.1.设置开始位置
        query.setFirstResult(3);
        // 2.2.设置每页记录数
        query.setMaxResults(3);
        // 3.调用方法得到结果
        List<Customer> list = query.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:投影查询
@Test
public void testSelect6() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        Query query = session.createQuery("select custLevel from Customer");
        // 2.调用方法得到结果
        List<Object> list = query.list();
        for (Object object : list) {
            System.out.println(object);
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:聚集函数的使用
@Test
public void testSelect7() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建query对象
        Query query = session.createQuery("select count(*) from Customer");
        // 2.调用方法得到结果
        // query对象里面有方法,直接返回对象形式
        Object obj = query.uniqueResult();
        // 返回int类型
        // int count=(int)obj;

        // 首先把object变成long类型,再变成int类型
        Long lobj = (Long) obj;
        int count = lobj.intValue();
        System.out.println(count);

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

}
复制代码
(3)HibernateQBC.java

复制代码
package cn.itcast.hibernantetest;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.criterion.DetachedCriteria;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.junit.Test;

import cn.itcast.entity.Customer;
import ustils.HibernateUtils;

public class HibernateQBC {

// 演示:查询所有
@Test
public void testSelect1() {

    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建对象
        Criteria criteria = session.createCriteria(Customer.class);
        // 2.调用方法得到结果
        List<Customer> list = criteria.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:条件查询
@Test
public void testSelect2() {

    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建criteria对象
        Criteria criteria = session.createCriteria(Customer.class);
        // 2.使用criteria对象里面的方法设置条件值
        // 首先使用add方法,表示设置条件值
        // 在add方法里面使用类的方法实现条件设置
        // 类似于cid=?
        // criteria.add(Restrictions.eq("cid", 1));
        // criteria.add(Restrictions.eq("custName", "玛莎拉蒂"));
        // 上面是eq,下面是like
        criteria.add(Restrictions.like("custName", "%百%"));
        // 3.调用方法得到结果
        List<Customer> list = criteria.list();

        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:排序查询
@Test
public void testSelect3() {

    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建对象
        Criteria criteria = session.createCriteria(Customer.class);
        // 2.设置对哪个属性进行排序,设置排序规则
        criteria.addOrder(Order.desc("cid"));
        // 3.调用方法,得到结果
        List<Customer> list = criteria.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:分页查询
@Test
public void testSelect4() {

    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建对象
        Criteria criteria = session.createCriteria(Customer.class);
        // 2.设置分页,起始和记录数
        criteria.setFirstResult(3);
        criteria.setMaxResults(3);
        // 3.调用方法得到结果
        List<Customer> list = criteria.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:统计查询
@Test
public void testSelect5() {

    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建对象
        Criteria criteria = session.createCriteria(Customer.class);
        // 2.设置操作
        criteria.setProjection(Projections.rowCount());
        // 3.调用方法得到结果
        Object obj = criteria.uniqueResult();
        Long lobj = (Long) obj;
        int count = lobj.intValue();
        System.out.println(count);

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

// 演示:离线查询
@Test
public void testSelect6() {

    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 1.创建对象
        // Criteria criteria = session.createCriteria(Customer.class);
        DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Customer.class);
        // 2.最终执行时候才需要得到session
        Criteria criteria = detachedCriteria.getExecutableCriteria(session);
        List<Customer> list = criteria.list();
        for (Customer customer : list) {
            System.out.println(customer.getCid() + "::" + customer.getCustName());
        }
        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }

}

}
复制代码
(4)HibernateManyTable.java

复制代码
package cn.itcast.hibernantetest;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.junit.Test;

import ustils.HibernateUtils;

public class HibernateManyTable {

// 演示hql内连接查询(2种)
@Test
public void testSelect1() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 内连接的list返回的是数组的形式;迫切内外连接的list放回的是对象的形式
        // Query query = session.createQuery("from Customer c inner join
        // c.setLinkMan");
        // List list = query.list();

        Query query = session.createQuery("from Customer c inner join fetch c.setLinkMan");
        List list = query.list();

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }
}

// 演示hql外连接查询(3种)
@Test
public void testSelect2() {
    SessionFactory sessionFactory = null;
    Session session = null;
    Transaction tx = null;
    try {
        sessionFactory = HibernateUtils.getSessionFactory();
        session = sessionFactory.openSession();
        tx = session.beginTransaction();

        // 左外连接的list返回的是数组的形式;迫切左外连接的list放回的是对象的形式
        // Query query = session.createQuery("from Customer c left outer
        // join c.setLinkMan");
        // List list = query.list();

        // Query query = session.createQuery("from Customer c left outer
        // join fetch c.setLinkMan");
        // List list = query.list();

        // 右外连接,没有迫切右外连接
        Query query = session.createQuery("from Customer c right outer join fetch c.setLinkMan");
        List list = query.list();

        tx.commit();
    } catch (Exception e) {
        e.printStackTrace();
        tx.rollback();
    } finally {
        session.close();
        sessionFactory.close();
    }
}

}
深圳网站建设www.sz886.com

第一部分 从Hibernate和EJB 3.0开始  第1章 理解对象/关系持久化    1.1 什么是持久化     1.1.1 关系数据库     1.1.2 理解SQL     1.1.3 在Java中使用SQL     1.1.4 面向对象应用程序中的持久化    1.2 范式不匹配     1.2.1 粒度问题     1.2.2 子类型问题     1.2.3 同一性问题     1.2.4 与关联相关的问题     1.2.5 数据导航的问题     1.2.6 不匹配的代价    1.3 持久层和其他层 显示全部信息第一部分 从Hibernate和EJB 3.0开始  第1章 理解对象/关系持久化    1.1 什么是持久化     1.1.1 关系数据库     1.1.2 理解SQL     1.1.3 在Java中使用SQL     1.1.4 面向对象应用程序中的持久化    1.2 范式不匹配     1.2.1 粒度问题     1.2.2 子类型问题     1.2.3 同一性问题     1.2.4 与关联相关的问题     1.2.5 数据导航的问题     1.2.6 不匹配的代价    1.3 持久层和其他层     1.3.1 分层架构     1.3.2 用SQL/JDBC手工编写持久层     1.3.3 使用序列化     1.3.4 面向对象的数据库系统     1.3.5 其他选项    1.4 ORM     1.4.1 什么是ORM     1.4.2 一般的ORM问题     1.4.3 为什么选择ORM     1.4.4 Hibernate、EJB 3和JPA简介    1.5 小结   第2章 启动项目    2.1 启动Hibernate项目     2.1.1 选择开发过程     2.1.2 建立项目     2.1.3 Hibernate配置和启动     2.1.4 运行和测试应用程序    2.2 启动Java Persistence项目     2.2.1 使用Hibernate Annotations     2.2.2 使用Hibernate EntityManager     2.2.3 引入EJB组件     2.2.4 切换到Hibernate接口    2.3 反向工程遗留数据库     2.3.1 创建数据库配置     2.3.2 定制反向工程     2.3.3 生成Java源代码    2.4 与Java EE服务整合     2.4.1 与JTA整合     2.4.2 JNDI绑定的SessionFactory     2.4.3 JMX服务部署    2.5 小结   第3章 领域模型和元数据    3.1 CaveatEmptor应用程序     3.1.1 分析业务领域     3.1.2 CaveatEmptor领域模型    3.2 实现领域模型     3.2.1 处理关注点渗漏     3.2.2 透明和自动持久化     3.2.3 编写POJO和持久化实体类     3.2.4 实现POJO关联     3.2.5 把逻辑添加到访问方法    3.3 ORM元数据     3.3.1 XML中的元数据     3.3.2 基于注解的元数据     3.3.3 使用XDoclet     3.3.4 处理全局的元数据     3.3.5 运行时操作元数据    3.4 其他实体表示法     3.4.1 创建动态的应用程序     3.4.2 表示XML中的数据    3.5 小结  第二部分 映射概念和策略  第4章 映射持久化类    4.1 理解实体和值类型     4.1.1 细粒度的领域模型     4.1.2 定义概念     4.1.3 识别实体和值类型    4.2 映射带有同一性的实体     4.2.1 理解Java同一性和等同性     4.2.2 处理数据库同一性     4.2.3 数据库主键    4.3 类映射选项     4.3.1 动态的SQL生成     4.3.2 使实体不可变     4.3.3 给查询命名实体     4.3.4 声明包名称     4.3.5 用引号把SQL标识符括起来     4.3.6 实现命名约定    4.4 细粒度的模型和映射     4.4.1 映射基础属性     4.4.2 映射组件    4.5 小结   第5章 继承和定制类型    5.1 映射类继承     5.1.1 每个带有隐式多态的具体类一张表     5.1.2 每个带有联合的具体类一张表     5.1.3 每个类层次结构一张表     5.1.4 每个子类一张表     5.1.5 混合继承策略     5.1.6 选择策略    5.2 Hibernate类型系统     5.2.1 概述实体和值类型     5.2.2 内建的映射类型     5.2.3 使用映射类型    5.3 创建定制的映射类型     5.3.1 考虑定制的映射类型     5.3.2 扩展点     5.3.3 定制映射类型的案例     5.3.4 创建UserType     5.3.5 创建CompositeUserType     5.3.6 参数化定制类型     5.3.7 映射枚举    5.4 小结   第6章 映射集合和实体关联    6.1 值类型的set、bag、list和map     6.1.1 选择集合接口     6.1.2 映射set     6.1.3 映射标识符bag     6.1.4 映射list     6.1.5 映射map     6.1.6 排序集合和有序集合  6.2 组件的集合     6.2.1 编写组件类     6.2.2 映射集合     6.2.3 启用双向导航     6.2.4 避免非空列    6.3 用注解映射集合     6.3.1 基本的集合映射     6.3.2 排序集合和有序集合     6.3.3 映射嵌入式对象的集合    6.4 映射父/子关系     6.4.1 多样性     6.4.2 最简单的可能关联     6.4.3 使关联双向     6.4.4 级联对象状态    6.5 小结   第7章 高级实体关联映射    7.1 单值的实体关联     7.1.1 共享的主键关联     7.1.2 一对一的外键关联     7.1.3 用联结表映射    7.2 多值的实体关联     7.2.1 一对多关联     7.2.2 多对多关联     7.2.3 把列添加到联结表     7.2.4 映射map    7.3 多态关联     7.3.1 多态的多对一关联     7.3.2 多态集合     7.3.3 对联合的多态关联     7.3.4 每个具体类一张多态表    7.4 小结   第8章 遗留数据库和定制SQL    8.1 整合遗留数据库     8.1.1 处理主键     8.1.2 带有公式的任意联结条件     8.1.3 联结任意的表     8.1.4 使用触发器    8.2 定制SQL     8.2.1 编写定制CRUD语句     8.2.2 整合存储过程和函数    8.3 改进Schema DDL     8.3.1 定制SQL名称和数据类型     8.3.2 确保数据一致性     8.3.3 添加领域约束和列约束     8.3.4 表级约束     8.3.5 数据库约束     8.3.6 创建索引     8.3.7 添加辅助的DDL    8.4 小结  第三部分 会话对象处理  第9章 使用对象    9.1 持久化生命周期     9.1.1 对象状态     9.1.2 持久化上下文    9.2 对象同一性和等同性     9.2.1 引入对话     9.2.2 对象同一性的范围     9.2.3 脱管对象的同一性     9.2.4 扩展持久化上下文    9.3 Hibernate接口     9.3.1 保存和加载对象     9.3.2 使用脱管对象     9.3.3 管理持久化上下文    9.4 JPA     9.4.1 保存和加载对象     9.4.2 使用脱管的实体实例    9.5 在EJB组件中使用Java Persistence     9.5.1 注入EntityManager     9.5.2 查找EntityManager     9.5.3 访问EntityManagerFactory    9.6 小结   第10章 事务和并发    10.1 事务本质     10.1.1 数据库和系统事务     10.1.2 Hibernate应用程序中的事务     10.1.3 使用Java Persistence的事务    10.2 控制并发访问     10.2.1 理解数据库级并发     10.2.2 乐观并发控制     10.2.3 获得额外的隔离性保证    10.3 非事务数据访问     10.3.1 揭开自动提交的神秘面纱     10.3.2 使用Hibernate非事务地工作     10.3.3 使用JTA的可选事务    10.4 小结   第11章 实现对话    11.1 传播Hibernate Session     11.1.1 Session传播的用例     11.1.2 通过线程局部传播     11.1.3 利用JTA传播     11.1.4 利用EJB传播    11.2 利用Hibernate的对话     11.2.1 提供对话保证     11.2.2 利用脱管对象的对话     11.2.3 给对话扩展Session    11.3 使用JPA的对话     11.3.1 Java SE中的持久化上下文传播     11.3.2 在对话中合并脱管对象     11.3.3 在Java SE中扩展持久化上下文    11.4 使用EJB 3.0的对话     11.4.1 使用EJB的上下文传播     11.4.2 利用EJB扩展持久化上下文    11.5 小结   第12章 有效修改对象    12.1 传播性持久化     12.1.1 按可到达性持久化     12.1.2 把级联应用到关联     12.1.3 使用传播性状态     12.1.4 利用JPA的传播性关联    12.2 大批量和批量操作     12.2.1 使用HQL和JPA QL的大批量语句     12.2.2 利用批量处理     12.2.3 使用无状态的会话    12.3 数据过滤和拦截     12.3.1 动态数据过滤     12.3.2 拦截Hibernate事件     12.3.3 内核事件系统     12.3.4 实体监听器和回调    12.4 小结   第13章 优化抓取和高速缓存    13.1 定义全局抓取计划     13.1.1 对象获取选项     13.1.2 延迟的默认抓取计划     13.1.3 理解代理     13.1.4 禁用代理生成     13.1.5 关联和集合的即时加载     13.1.6 通过拦截延迟加载    13.2 选择抓取策略     13.2.1 批量预抓取数据     13.2.2 通过子查询预抓取集合     13.2.3 通过联结即时抓取     13.2.4 给二级表优化抓取     13.2.5 优化指导方针    13.3 高速缓存基本原理     13.3.1 高速缓存策略和范围     13.3.2 Hibernate高速缓存架构    13.4 高速缓存实践     13.4.1 选择并发控制策略     13.4.2 理解高速缓存区域     13.4.3 设置本地的高速缓存提供程序     13.4.4 设置重复的高速缓存     13.4.5 控制二级高速缓存    13.5 小结   第14章 利用HQL和JPA QL查询    14.1 创建和运行查询     14.1.1 准备查询     14.1.2 执行查询     14.1.3 使用具名查询    14.2 基本的HQL和JPA QL查询     14.2.1 选择     14.2.2 限制     14.2.3 投影    14.3 联结、报表查询和子查询     14.3.1 联结关系和关联     14.3.2 报表查询     14.3.3 利用子查询    14.4 小结   第15章 高级查询选项    15.1 利用条件和示例查询     15.1.1 基本的条件查询     15.1.2 联结和动态抓取     15.1.3 投影和报表查询     15.1.4 按示例查询    15.2 利用原生的SQL查询     15.2.1 自动的结果集处理     15.2.2 获取标量值     15.2.3 Java Persistence中的原生SQL    15.3 过滤集合    15.4 高速缓存查询结果     15.4.1 启用查询结果高速缓存     15.4.2 理解查询高速缓存     15.4.3 什么时候使用查询高速缓存     15.4.4 自然标识符高速缓存查找    15.5 小结   第16章 创建和测试分层的应用程序    16.1 Web应用程序中的Hibernate     16.1.1 用例简介     16.1.2 编写控制器     16.1.3 OSIV模式     16.1.4 设计巧妙的领域模型    16.2 创建持久层     16.2.1 泛型的数据访问对象模式     16.2.2 实现泛型CRUD接口     16.2.3 实现实体DAO     16.2.4 利用数据访问对象    16.3 命令模式简介     16.3.1 基础接口     16.3.2 执行命令对象     16.3.3 命令模式的变形    16.4 利用EJB 3.0设计应用程序     16.4.1 利用有状态的bean实现会话     16.4.2 利用EJB编写DAO     16.4.3 利用依赖注入    16.5 测试     16.5.1 理解不同种类的测试     16.5.2 TestNG简介     16.5.3 测试持久层     16.5.4 考虑性能基准    16.6 小结   第17章 JBoss Seam简介    17.1 Java EE 5.0编程模型     17.1.1 JSF详解     17.1.2 EJB 3.0详解     17.1.3 用JSF和EJB 3.0编写Web应用程序     17.1.4 分析应用程序    17.2 用Seam改善应用程序     17.2.1 配置Seam     17.2.2 将页面绑定到有状态的Seam组件     17.2.3 分析Seam应用程序    17.3 理解上下文组件     17.3.1 编写登录页面     17.3.2 创建组件     17.3.3 给上下文变量起别名     17.3.4 完成登录/注销特性    17.4 验证用户输入     17.4.1 Hibernate Validator简介     17.4.2 创建注册页面     17.4.3 用Seam实现国际化    17.5 利用Seam简化持久化     17.5.1 实现对话     17.5.2 让Seam管理持久化上下文    17.6 小结  附录A SQL基础知识  附录B 映射快速参考
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值