hibernate基础的hbm.xml配置内容

1、hibernate基本环境搭建:

 导入required目录中的所有包,导入日志输出需要的包(log4j.*.jar; slf4j-api.*.jar; slf4-log4j.*.jar),导入mysql的驱动jar包;

2、创建一个实体类,实体类中有属性必须为唯一值,需要和表中的主键对应(使用hibernate,不需要自己手动建表,hibernate可以实现);

3、配置实体类和数据库表的一一对应关系(映射关系),使用xml来做映射配置文件;

 (1)创建xml格式的配置文件(名称和位置不做固定要求,官方建议创建在实体类所在的包中,命名为:实体类名称.hbm.xml);

 (2)配置文件中首先引入xml约束(DTD和schema,目前使用DTD)(约束文件名:hibernate-mapping-3.0.dtd);

 (3)配置映射关系如下表

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 
<hibernate-mapping>
	<!-- 1、配置类和表的映射 
		name属性:实体类的全路径
		table属性:数据库表名称
	-->
	<class name="cn.itcast.entity.User" table="t_user">
	
		<!-- 2、配置实体类id和表id对应
				hibernate中要求实体类有一个属性唯一值;
				hibernate要求表有字段作为唯一值主键primary key
		 -->
		 <!-- id标签
		 		name属性:实体类里面id属性名称
		 		column属性:生成的表的字段名称
		  -->
		<id name="uid" column="uid">
			<!-- 设置数据库表id的生成策略generator
					native:生成表id值就是主键自动增长
			 -->
			<generator class="native"></generator>
		</id>
		<!-- 配置其他的属性和表字段的对应 
			name属性:实体类属性名称
			column属性:相对应的生成的表的字段名称
		-->
		<property name="username" column="username"></property>
		<property name="password" column="password"></property>
		<property name="address" column="address"></property>
		
		
	</class>

</hibernate-mapping>

4、创建hibernate的核心配置文件

 (1)核心配置文件格式为xml,名称和位置必须固定,名称为hibernate.cfg.xml,位置中/src目录下面;

 (2)引入DTD约束(文件:hibernate-configuration-3.0.dtd);

 (3)hibernate的操作过程,只会加载核心配置文件,不会加载其他配置文件;(相关配置信息参考hibernate.properties文件)

  1】配置数据库信息,相关的驱动,数据库url,用户名,密码;

   2】配置hibernate信息;

   3】把第3步的映射文件放入核心配置文件中来;

<?xml version="1.0" encoding="UTF-8"?>
<!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>
		<!-- 第一部分 配置数据库信息 必填的-->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql:///hibernate_day1</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">root</property>
		
		
		<!-- 第二部分 配置hibernate信息 可选的-->
		<!-- 输出底层sql语句-->
		<property name="hibernate.show_sql">true</property>
		<!-- 输出底层sql语句格式-->
		<property name="hibernate.format_sql">true</property>
		<!-- hibernate帮助创建表,需要配置之后
			update值:如果已经有表,更新,如果没有,则创建
		-->
		<property name="hibernate.hbm2ddl.auto">update</property>
		<!-- 配置数据库方言
			mysql里面实现分页,关键字limit,只能使用mysql里
			中oracle数据库,实现分页rownum
			让hibernate框架识别不同数据库的自己特有的语句
		-->
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		
		
		<!-- 第三部分 把映射文件放到核心配置文件中 必须的 -->
		<!-- resource属性的地址为相对hibernate.cfg.xml的地址 -->
		<mapping resource="cn/itcast/entity/User.hbm.xml"></mapping>
		
	
	</session-factory>
</hibernate-configuration>

5、做简单的测试,基本的操作流程

 第一步 加载hibernate核心配置文件

 第二步 创建SessionFactory对象

 第三步 使用SessionFactory来创建Session对象

 第四步 开启事务

 第五步 写具体逻辑crud操作(基本上就只需要操作这部分)

 第六步 提交事务

 第七步 关闭资源

package cn.itcast.hibernatetest;

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

import cn.itcast.entity.User;

public class HibernateDemo {
	
	@Test
	public void testAdd() {
//		第一步 加载hibernate核心配置文件
		//到/src目录下找到名称为hibernate.cfg.xml的核心配置文件
		//hibernate里面封装对象
		Configuration cfg = new Configuration();
		cfg.configure();

//		第二步 创建SessionFactory对象
		//读取hibernate核心配置文件内容,创建sessionFactory
		//在过程中,根据映射关系,在配置数据库里面将表创建起来
		SessionFactory sessionFactory = cfg.buildSessionFactory();
		
//		第三步 使用SessionFactory来创建Session对象
		//类似于连接(会话)
		Session session = sessionFactory.openSession();
		
//		第四步 开启事务
		Transaction tx = session.beginTransaction();

//		第五步 写具体逻辑crud操作
		//添加功能
		User user = new User();
		user.setUsername("xiaoming");
		user.setPassword("250");
		user.setAddress("shanghai");
		//调用session的方法实现添加
		session.save(user);

//		第六步 提交事务
		tx.commit();

//		第七步 关闭资源
		//后开先关,先开后关
		session.close();
		sessionFactory.close();
	}

}





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值