4.Hibernate的映射配置

本文主要介绍了Hibernate的映射配置,包括如何在主配置文件中加载映射文件,以及通过在类中加载的方式进行测试。此外,还涉及了映射文件的详细解析以及复合主键的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

1.映射文件的加载

在主配置文件配置

<mapping resource="cn/itcast/a_hello/Employee.hbm.xml"/>

在类中加载(测试用)

private static SessionFactory sf;
    static  {        
        // 创建sf对象
        sf = new Configuration()
            .configure()
            .addClass(Employee.class)  //(测试) 会自动加载映射文件:Employee.hbm.xml,,当前包下与类名相同的映射文件
            .buildSessionFactory();
    }

2.映射文件详解

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">


<!-- 映射文件: 映射一个实体类对象;  描述一个对象最终实现可以直接保存对象数据到数据库中。  -->
<!-- 
	package: 要映射的对象所在的包(可选,如果不指定,此文件所有的类都要指定全路径)
	auto-import 默认为true, 在写hql的时候自动导入包名
				如果指定为false, 再写hql的时候必须要写上类的全名;
				  如:session.createQuery("from cn.itcast.c_hbm_config.Employee").list();
 -->
<hibernate-mapping package="cn.itcast.c_hbm_config" auto-import="true">
	
	<!-- 
		class 映射某一个对象的(一般情况,一个对象写一个映射文件,即一个class节点)
			name 指定要映射的对象的类型
			table 指定对象对应的表;
				  如果没有指定表名,默认与对象名称一样 
	 -->
	<class name="Employee" table="employee">
		
		<!-- 主键 ,映射-->
		<id name="empId" column="id">
			<!-- 
				主键的生成策略
					identity  自增长(mysql,db2)
					sequence  自增长(序列), oracle中自增长是以序列方法实现
					native  自增长【会根据底层数据库自增长的方式选择identity或sequence】
							如果是mysql数据库, 采用的自增长方式是identity
							如果是oracle数据库, 使用sequence序列的方式实现自增长
					
					increment  自增长(会有并发访问的问题,一般在服务器集群环境使用会存在问题。)
					
					assigned  指定主键生成策略为手动指定主键的值
					uuid      指定uuid随机生成的唯一的值
					foreign   (外键的方式, one-to-one讲)
			 -->
			<generator class="uuid"/>
		</id>
		
		<!-- 
			普通字段映射
			property
				name  指定对象的属性名称
				column 指定对象属性对应的表的字段名称,如果不写默认与对象属性一致。
				length 指定字符的长度, 默认为255
				type   指定映射表的字段的类型,如果不指定会匹配属性的类型
					java类型:     必须写全名
					hibernate类型:  直接写类型,都是小写
		-->
		<property name="empName" column="empName" type="java.lang.String" length="20"></property>
		<property name="workDate" type="java.util.Date"></property>
		<!-- 如果列名称为数据库关键字,需要用反引号或改列名。 -->
		<property name="desc" column="`desc`" type="java.lang.String"></property>
		
	</class>
	

</hibernate-mapping>

3.复合主键

// 复合主键类

public class CompositeKeys implements Serializable{

    private String userName;

    private String address;

   // .. get/set

}

public class User {

 

    // 名字跟地址,不会重复

    private CompositeKeys keys;

    private int age;

}

User.hbm.xml

<?xml version="1.0"?>

<!DOCTYPE hibernate-mapping PUBLIC

    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

 

<hibernate-mapping package="cn.itcast.d_compositeKey" auto-import="true">

   

    <class name="User">

       

        <!-- 复合主键映射 -->

        <composite-id name="keys">

            <key-property name="userName" type="string"></key-property>

            <key-property name="address" type="string"></key-property>

        </composite-id>

       

        <property name="age" type="int"></property>       

       

    </class>

   

 

</hibernate-mapping>

 

App.java

 

public class App2 {

   

    private static SessionFactory sf;

    static  {      

        // 创建sf对象

        sf = new Configuration()

            .configure()

            .addClass(User.class//(测试) 会自动加载映射文件:Employee.hbm.xml

            .buildSessionFactory();

    }

 

    //1. 保存对象

    @Test

    public void testSave() throws Exception {

        Session session = sf.openSession();

        Transaction tx = session.beginTransaction();

       

        // 对象

        CompositeKeys keys = new CompositeKeys();

        keys.setAddress("广州棠东");

        keys.setUserName("Jack");

        User user = new User();

        user.setAge(20);

        user.setKeys(keys);

       

        // 保存

        session.save(user);

       

       

        tx.commit();

        session.close();

    }

   

    @Test

    public void testGet() throws Exception {

        Session session = sf.openSession();

        Transaction tx = session.beginTransaction();

       

        //构建主键再查询

        CompositeKeys keys = new CompositeKeys();

        keys.setAddress("广州棠东");

        keys.setUserName("Jack");

       

        // 主键查询

        User user = (User) session.get(User.class, keys);

        // 测试输出

        if (user != null){

            System.out.println(user.getKeys().getUserName());

            System.out.println(user.getKeys().getAddress());

            System.out.println(user.getAge());

        }

       

       

        tx.commit();

        session.close();

    }

}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值