Hibernate(四)主键属性

这些属性什么的用到的时候直接查api文档就行了。但api文档对于没有经验的初学者可能有些困难。
这里主要是介绍映射文件主键的生成策略。因为用到Hibernate就会用到,所以比较重要。
实体类

package test.hibernate.hbmProperty;

public class User {

    private String id;
    private String name;
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

}

测试类

package test.hibernate.hbmProperty;

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

public class App {

    private static SessionFactory sessionFactory = new Configuration()//
            .configure()//
            .addClass(User.class)// 添加Hibernate实体类(加载对应的映射文件)
            .buildSessionFactory();

    @Test
    public void testSave() throws Exception {
        Session session = sessionFactory.openSession();
        session.beginTransaction();
        // --------------------------------------------

        // 构建对象
        User user = new User();
        // user.setId(UUID.randomUUID().toString());//id设为String类型
        user.setName("张三");

        // 保存
        session.save(user);
        // session.save(new User());

        // --------------------------------------------
        session.getTransaction().commit();
        session.close();
    }
}

注意一些模板代码,会话工厂、打开会话、事务的开始关闭…
文件配置

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

<hibernate-mapping package="test.hibernate.hbmProperty">
    <class name="User" table="t_user">

        <!-- id元素用于映射主键。 子元素generator是用于指定主键生成策略的。 -->
        <id name="id">
            <!-- identity:使用数据库的自动增长策略,不是所有数据库都支持,比如oracle就不支持 <generator class="identity"/> -->

            <!-- sequence:在 DB2,PostgreSQL,Oracle,SAP DB,McKoi 中使用序列(sequence) 在使用Oracle数据库时可以使用这一个 
                <generator class="sequence"/> -->

            <!-- hilo,使用高低位算法生成主键值。 只需要一张额外表,所有的数据都支持。 <generator class="hilo"> <param 
                name="table">hi_value</param> <param name="column">next_value</param> <param 
                name="max_lo">100</param> </generator> -->

            <!-- 根据底层数据库的能力选择 identity、sequence 或者 hilo中的一个。 <generator class="native"></generator> -->

            <!-- increment:由Hibernate维护的自动增长。 先查询当前最大的id值,再加1使用 不推荐使用,因为在多线程下会问题。 
                <generator class="increment"></generator> -->

            <!-- assigned:手工指定主键值 <generator class="assigned"></generator> -->

            <!-- uuid:由Hibernate自动生成UUID并指定为主键值。 -->
            <generator class="uuid"></generator>

        </id>

        <property name="name" />
    </class>
</hibernate-mapping>

这里写图片描述
数据库表唯一标识主键可以用Integer递增的方式,也可以用uudi,用一个三十几位的字符串唯一标识,由数据库自己生成。
主配置文件hibernate.cfg.xml

<!DOCTYPE hibernate-configuration PUBLIC
    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory name="foo">
        <!-- 配置数据库信息 -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate_2015</property>
        <!-- 可简写为<property name="connection.url">jdbc:mysql:///hibernate_2015</property> -->
        <property name="connection.username">root</property>
        <property name="connection.password">686175</property>
        <!-- 显示生成的sql语句,不写的话默认是false -->
        <property name="show_sql">true</property>
        <property name="hbm2ddl.auto">update</property>

        <!--  <mapping resource="test/hibernate/domain/User.hbm.xml" />
        <mapping resource="test/hibernate/hbmProperty/User.hbm.xml" />-->
    </session-factory>
</hibernate-configuration>

原文出处:http://blog.csdn.net/lindonglian/article/details/46878855

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值