在HIbernate中,实体类如何映射到数据库

在HIbernate中,实体类如何映射到数据库,第1张

是通过映射文件来映射的。举个简单的例子,例如我有个Teacher实体类(某教学管理系统老师用户):

private Integer id //编号

private String name //姓名

private String password //密码

private Date createDate //创建日期

同时,我创建了数据表TEACHER:

create table teacher( id number(9) primary key, --编号 name varchar2(20), --姓名 password varchar2(20), --密码 create_date date --创建日期 )

这时,怎么关联它们呢?通过加载hibernate框架,我们就可以使用映射文件来关联实体类和数据库

文件名:Teacher.hbm.xml(必须与实体类名字一致)

内容:

<?xml version="1.0" encoding="utf-8"?>

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

<!-- Mapping file autogenerated by MyEclipse Persistence Tools-->

<hibernate-mapping>

<class name="com.yss.Teacher" table="TEACHER" schema="WZM">

<id name="id" type="java.lang.Integer">

<column name="ID" precision="9" />

</id>

<property name="name" type="java.lang.String">

<column name="NAME" length="20" />

</property>

<property name="password" type="java.lang.String">

<column name="PASSWORD" length="20" />

</property>

<property name="createDate" type="java.util.Date">

<column name="CREATE_DATE" length="7" />

</property>

</class>

</hibernate-mapping>

当然,这只是比较简单的映射,还有什么多对多,一对多等映射,并且映射时如何设置以达到需要的效果,这些你可以在网上搜索相关资料自行查看。

Hibernate支持自动建表,在开发阶段很方便,可以保证hbm与数据库表结构的自动同步。

如何使用呢?很简单,只要在hibernate.cfg.xml里加上如下代码

Xml代码<property name="hbm2ddl.auto">update</property>

update:表示自动根据model对象来更新表结构,启动hibernate时会自动检查数据库,如果缺少表,则自动建表;如果表里缺少列,则自动添加列。

还有其他的参数:

create:启动hibernate时,自动删除原来的表,新建所有的表,所以每次启动后的以前数据都会丢失。

create-drop:启动hibernate时,自动创建表,程序关闭时,自动把相应的表都删除。所以程序结束时,表和数据也不会再存在。

PS:数据库要预先建立好,因为hibernate只会建表,不会建库


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9917833.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存