hibernate实体类型映射文件
1.通过写hibernate映射文件。实体类型转换为数据库中的表
据实体类型而写的。
实体类型User.java
package cn.wwh.www.hibernate.dd.property; import java.util.Arrays;
import java.util.Date; /**
*类的作用:
*
*
*@author 一叶扁舟
*@version 1.0
*@创建时间: 2014-8-17 下午08:05:30
*/
public class User {
private Integer id;
private String name; // 姓名
private boolean gender; // true表示男。false表示女
private Date birthday; // 生日
private String desc; // 一大段说明,最多为5000字
private byte[] photo; // 照片
/**
* @return the id
*/
public Integer getId() {
return id;
}
/**
* @param id the id to set
*/
public void setId(Integer id) {
this.id = id;
}
/**
* @return the name
*/
public String getName() {
return name;
}
/**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}
/**
* @return the gender
*/
public boolean isGender() {
return gender;
}
/**
* @param gender the gender to set
*/
public void setGender(boolean gender) {
this.gender = gender;
}
/**
* @return the birthday
*/
public Date getBirthday() {
return birthday;
}
/**
* @param birthday the birthday to set
*/
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
/**
* @return the desc
*/
public String getDesc() {
return desc;
}
/**
* @param desc the desc to set
*/
public void setDesc(String desc) {
this.desc = desc;
}
/**
* @return the photo
*/
public byte[] getPhoto() {
return photo;
}
/**
* @param photo the photo to set
*/
public void setPhoto(byte[] photo) {
this.photo = photo;
}
@Override
public String toString() {
return "User [birthday=" + birthday + "\n desc=" + desc + "\n gender="
+ gender + "\n id=" + id + "\n name=" + name + "\n photo="
+ Arrays.toString(photo) + "]";
} }
2.映射文件User.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"> <hibernate-mapping>
<!-- 类名相应于数据库中的表名 -->
<class name="cn.wwh.www.hibernate.dd.property.User" table="user">
<id name="id" type="int" column="id" >
<generator class="native"></generator>
</id>
<!--
name:对象中的属性名。必需要有
type:数据的类型。不写时会自己主动检測
column:相应的列名。不写时默觉得属性的名称
not-null:true/false。是否有非空约束,默觉得false
length:长度,默觉得255
-->
<!--
<property name="name" type="string" column="name" not-null="true" length="35"/>
<property name="name" type="string">
<column name="name_" not-null="true" length="55"></column>
</property>
-->
<property name="name" type="string" column="name" not-null="true"></property>
<property name="gender"></property>
<!-- 对于日期要指定类型 -->
<property name="birthday" type="date"></property>
<!-- 大文本数据要指定长度,因为desc是数据库中的keyword。要用反单引號 -->
<property name="desc" type="text" column="`desc`" length="5000"></property>
<!-- 对于二进制数据类型。要指定长度 -->
<property name="photo" type="binary" column="photo" length="888888"></property>
</class> </hibernate-mapping>
3.主配置文件:
hibernate.cfg.xml
<? xml version="1.0" encoding="UTF-8"? >
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
<session-factory> <!-- 1、数据库信息:数据库方言(是一个类的全名)与数据库连接信息 -->
<!-- 配置连接数据库所需的驱动 -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 连接数据库的数据库url -->
<property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
<!-- 数据库的账号 -->
<property name="connection.username">root</property>
<!-- 数据库的密码 -->
<property name="connection.password">wwh</property>
<!-- 指定数据库的方言(本人用的是MySql) -->
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 2.配置其他 -->
<!--
create: 先删表。再建表。
create-drop: 启动时建表,退出前删表。
<span style="white-space:pre"> </span> update: 假设表结构不一致,就创建或更新。
validate: 启动时验证表结构,假设不致就抛异常。
-->
<!-- 自己主动创建数据表 -->
<property name="hbm2ddl.auto">update</property>
<!-- 显示数据操作的sql语句 -->
<property name="show_sql">true</property>
<!-- 格式化的显示sql语句 -->
<property name="format_sql">true</property>
<!-- 3.导入映射配置文件 -->
<mapping resource="cn/wwh/www/hibernate/dd/property/User.hbm.xml"/> </session-factory> </hibernate-configuration>
4.測试数据库中的数据:
package cn.wwh.www.hibernate.dd.property; import java.io.FileInputStream;
import java.util.Date; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.junit.Test; /**
*类的作用:
*
*
*@author 一叶扁舟
*@version 1.0
*@创建时间: 2014-8-17 下午08:10:38
*/
public class TestSqlByXml { private static SessionFactory sessionFactory = new Configuration()
.configure()
.buildSessionFactory(); // 保存
@Test
public void testSave() throws Exception {
Session session = sessionFactory.openSession();
session.beginTransaction();
// --------------------------------------- // 从硬盘中读取图片。然后存储数据库中
FileInputStream in = new FileInputStream("F:/psb.jpg");
byte[] photo = new byte[in.available()];
in.read(photo);
in.close(); // 准备对象
User user = new User();
user.setName("一叶扁舟");
user.setGender(true);
user.setBirthday(new Date());
user.setDesc("一叶扁舟是一个积极向上的孩子,为梦想而努力奋斗着…………");
user.setPhoto(photo); // 保存
session.save(user); // ---------------------------------------
session.getTransaction().commit();
session.close();
} // 获取
@Test
public void testGet() throws Exception {
Session session = sessionFactory.openSession();
session.beginTransaction();
// --------------------------------------- User user = (User) session.get(User.class, 1);
System.out.println(user.getName());
System.out.println(user.isGender());
System.out.println(user.getBirthday());
System.out.println(user.getDesc());
System.out.println(user.getPhoto());
// System.out.println(user); // ---------------------------------------
session.getTransaction().commit();
session.close();
} }
版权声明:本文博客原创文章,博客,未经同意,不得转载。
hibernate实体类型映射文件的更多相关文章
- Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件
原文:转:Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件 2011-04-30 12:50 很多人不知道怎么用 IntelliJ IDE ...
- hibernate 实体关系映射笔记
@经常使用属性说明: @Entity:实体类 @Table:指定相应数据表 @Id:主键,使用能够为null值的类型,假设实体类没有保存到数据库是一个暂时状态 @Col ...
- [hibernate]基本值类型映射之日期类型
hibernate基本值类型映射中日期类型支持date,time,timestamp这三个选项,其中 date:对应数据库中的date类型,表示只显示日期 time:对应数据库中的time类型,表示只 ...
- hibernate之xml映射文件关系维护,懒加载,级联
一:关系维护 --->inverse默认值false,表示不放弃关系的维护. --->inverse="true"配置在那一端,表示那一端xml对应的po放弃关系的 ...
- 【转】hibernate中的映射文件xxx.hbm.xml详解总结
一.Hibernate映射文件的作用: Hibernate映射文件是Hibernate与数据库进行持久化的桥梁 二,Hibernate映射文件主要内容: (1).映射内容的定义: Hibern ...
- hibernate中的映射文件xxx.hbm.xml详解总结
转自 http://blog.csdn.net/a9529lty/article/details/6454924 一.hibernate映射文件的作用: Hibernate映射文件是Hibernate ...
- Hibernate 配置文件与映射文件 总结
hibernate是一个彻底的ORM(Object Relational Mapping,对象关系映射)开源框架. 一.Hibernate配置文件详解 Hibernate配置文件有两种形式:XML与p ...
- hibernate自动生成映射文件
映射文件是O/R Mapping的关键,相当于控制中心.当数据库表较多时,手动配置该映射文件非常耗时.为了快速开发程序,使开发人员的注意力集中到业务逻辑上来,Hibernate官方提供的MiddleG ...
- hibernate多对多映射文件详解(一)
1.仓库表属性 public class WarehouseNew implements java.io.Serializable { // Fields private static final l ...
随机推荐
- lodoop打印控制具体解释
注意:这就需要引进的打印控制(我上传Demo同时): install_lodop32.exe install_lodop64.exe LodopFuncs.js jquery-1.10.0.min.j ...
- LeetCode 48 Anagrams
Given an array of strings, return all groups of strings that are anagrams. Note: All inputs will be ...
- Bye,IE!服务互联网20年IE终于要退役了
美国当地时间16日中午,Microsoft Edge官微发表了祝词:Internet Explorer 20岁生日快乐!你在过去做出了巨大贡献,今后由我继续发扬光大.服务互联网20年之后,IE终于要退 ...
- 记录我第一次在Android开发图像处理算法的经历
大概是四月底的时候.有人加我QQ问我是否做能做一些基于图像皮肤检測的算法, 主要是实现对皮肤六项指标: 1. 水分 2. 有份 3. 痤疮与痘痘 4. 色斑与肤 ...
- 一个人ACM(我们赶上了ACM)
时间过得真快,不经意间我已经花了两年的大学生活,现在是时候写的东西.纪念馆两年左右的时间,最近一直在玩博客.我写了一个博客.纪念我们终将逝去的青春. 就从报考说起吧.高考成绩一般,自己选择了土建类的学 ...
- Java的结构之美【1】——构造对象
当我们遇到多个构造器參数的时候可能会想到用构件器,代码例如以下: /** * 构建器 * @author 阳光小强 * */ public class Lunch { private String c ...
- ios7 JavaScriptCore.framework
曾经想要oc调用js代码通常是通过uiwebview的stringByEvaluatingJavaScriptFromString方法,或是直接使用JavaScriptCore引擎,比如https:/ ...
- 【电视桌面CSWUI】电视桌面(launcher)截图欣赏
网络播放器是最重要的电视桌面.cswui,我们公司做了一个非常大的人力,物力搞一个电视柜.后来一一介绍,简言之发送屏幕截图.给大家看. watermark/2/text/aHR0cDovL2Jsb2c ...
- hdu 5060 War
War Time Limit: 8000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- debugging python with IDLE
1. start IDLE "Python 2.5"→"IDLE(Python GUI)" 2. open your source file window Fr ...