当前位置:首页 » 操作系统 » hibernate数据库映射

hibernate数据库映射

发布时间: 2023-04-29 15:29:29

1. hibernate映射数据库表如何使表中字段默认值生效

解决方法:
在hibernate映射文件对数据库表的描述中,在当前字段处加入insert="false"语句,这时hibernate在进行插入操作时,只会为那些有实值的字段赋值,而值为空白的字段就会使用数据库表中定义的默认值了。

举例说明,表person:

sql">CREATETABLEaddress(
i_idint(11)NOTNULLauto_increment,
c_addressvarchar(100)NOTNULLdefault'中国',
PRIMARYKEY(id)
)
address.hbm.xml:
<hibernate-mappingpackage="cn.com.lough.model">
<class
name="address"
table="address"
lazy="false"
>
<metaattribute="sync-DAO">true</meta>
<cacheusage="read-write"/>
<id
name="IId"
type="integer"
column="i_id"
>
<generatorclass="native"/>
</id>
<property
name="C_Address"
column="c_address"
type="string"
not-null="false"
length="128"
/>
</hibernate-mapping>
运行程序
publicregAddress(Stringa){//传入的值a未在网页文本框里获得任何值(家庭地址)
Addressp=newAddress();
p.setAddress(a);
HiFactory.save(p);
}
此时hibernate生成的sql语句为insertintoperson(c_address)values('');
数据库表结果为
i_idc_address
1null
修改address.hbm.xml为:
<hibernate-mappingpackage="cn.com.lough.model">
<class
name="Address"
table="address"
lazy="false"
>
<metaattribute="sync-DAO">true</meta>
<cacheusage="read-write"/>
<id
name="IId"
type="integer"
column="i_id"
>
<generatorclass="native"/>
</id>
<property
name="C_Address"
column="c_address"
type="string"
not-null="false"
length="128"
insert="false"
/>
</hibernate-mapping>
再次运行程序,此时hibernate生成的sql语句为insertintoaddress()values();

2. 数据库表在两个数据库中,怎么进行hibernate映射呢

前提是你数据源配置正确.
映射文件中:
注意看class属性:
name是你的model类(包名+类名)
table是你数据库里的表名
catalog是你的数据库名
<hibernate-mapping>
<class name="com.cwx.model.Xsb" table="XSB" schema="dbo" catalog="XSCJ">
......
</class>
</hibernate-mapping>

3. Hibernate的类型怎样映射数据库中字段的自定义类型

在hibernate的xml映射文件中可以配置实体属性与数据库字段间的对应关系。如下:
<property name="salary" precision="2" scale="10" length="255"
column="salary" type="string" update="true" insert="true"
lazy="false" unique="false" not-null="false">
</property>

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

是通过映射文件来映射的。举个简单的例子,例如我有个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>
当然,这只是比较简单的映射,还有什么多对多,一对多等映射,并且映射时如何设置以达到需要的效果,这些你可以在网上搜索相关资料自行查看。

热点内容
ps2020版本怎么调整存储盘 发布:2025-09-14 07:20:28 浏览:852
奥迪a6哪个配置最保值 发布:2025-09-14 07:11:53 浏览:978
android查看文件 发布:2025-09-14 07:00:37 浏览:284
carlyle压缩机 发布:2025-09-14 06:16:51 浏览:969
支持ftp免费空间 发布:2025-09-14 06:05:16 浏览:199
android横屏生命周期 发布:2025-09-14 05:55:27 浏览:414
金税盘密码重置口令多少 发布:2025-09-14 05:55:19 浏览:347
pythonfor多线程 发布:2025-09-14 05:53:56 浏览:992
如何把软件复制到服务器 发布:2025-09-14 05:50:13 浏览:9
oracle的存储过程和函数的区别 发布:2025-09-14 05:40:28 浏览:762