rge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!--显示执行的SQL语句--> <property name="show_sql">true</property> <!--连接字符串--> <property name="connection.url">jdbc:mysql://localhost:3306/STU</property> <!--连接数据库的用户名--> <property name="connection.username">root</property> <!--数据库用户密码--> <property name="connection.password">root</property> <!--数据库驱动--> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <!--选择使用的方言--> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!--映射文件 --> <mapping resource="com/stuman/domain/Admin.hbm.xml" /> <!--映射文件--> <mapping resource="com/stuman/domain/Student.hbm.xml" /> </session-factory> </hibernate-configuration> properties形式的配置文件和XML格式的配置文件可以同时使用。当同时使用两种类型的配置文件时,XML配置文件中的设置会覆盖properties配置文件的相同的属性。 对象标识符号 在关系数据库表中,主键(Primary Key)用来识别记录,并保证每条记录的唯一性。在Java语言中,通过比较两个变量所引用对象的内存地址是否相同,或者比较两个变量引用的对象值是否相同来判断两对象是否相等。Hibernate为了解决两者之间的不同,使用对象标识符(OID)来标识对象的唯一性。OID是关系数据库中主键在Java对象模型中的等价物。在运行时,Hibernate根据OID来维持Java对象和数据库表中记录的对应关系。如下代码所示,三次调用了Session的load()方法,分别加载OID为1或3的User对象。 Transaction tx = session.beginTransaction(); User user1 = (User)session.load(User.class,new Long(1)); User user2 = (User)session.load(User.class,new Long(1)); User user3 = (User)session.load(User.class,new Long(3)); System.out.println( user1 == user2 ); System.out.println( user1 == user3 ); 应用
程序在执行上述代码时,第一次加载OID为1的User对象,从数据库中查找ID为1的记录,然后创建相应的User实例,并把它保存在Session缓存中,最后将该实例的引用赋值给变量user1。第二次加载OID为1的对象时,直接把Session缓存中OID为1的实例的引用赋值给变量user2。因此,表达式user1==user2的结果为true。 标识的生成可以使用不同的策略,表1为Hibernate内置的标识生成策略。 表1:Hibernate标识生成策略 标识符生成器
描述increment
适用于代理主键。由Hibernate自动以递增方式生成。identity
适用于代理主键。由底层数据库生成标识符。sequence
适用于代理主键。Hibernate根据底层数据库的序列生成标识符,这要求底层数据库支持序列。hilo
适用于代理主键。Hibernate分局high/low算法生成标识符。seqhilo
适用于代理主键。使用一个高/低位算法来高效的生成long,short或者int类型的标识符。native
适用于代理主键。根据底层数据库对自动生成标识符的方式,自动选择identity、sequence或hilo。uuid.hex
适用于代理主键。Hibernate采用128位的UUID算法生成标识