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 ...
随机推荐
- git常用命令学习(转)
一.Bug分支 1,假设如下场景,你正在dev分支工作,突然接到一个修复代号为101的bug的任务时,dev的东西还没不能提交,但是bug需要马上修复. Git提供了一个stash功能,可以把当前工作 ...
- 深入浅出java并发
http://www.blogjava.net/xylz/archive/2010/07/08/325587.html
- 【2014 Multi-University Training Contest 2 1002】/【HDU 4873】 ZCC Loves Intersection
果然,或滥用零件,啥都不说了.我们欣慰地学习阅读.这两天残疾儿童是数学. 这是求所需的问题,不明确.贴上官方的解题报告. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi ...
- Team Foundation Server 2015使用教程--默认团队成员添加
- Windows 怎么知道我已连线到网际网络? 原来当中大有文章!
原文 Windows 怎么知道我已连线到网际网络? 原来当中大有文章! 标题这个问题好像很简单, 但原来深入研究起来还真的不是”因为我能看到网页嘛”这样简单的答案. 研究这个课题是由于公司内部的防火墙 ...
- Web Host消息处理管道
Web Host消息处理管道 前言 我们知道Web API本身是无法提供请求-响应的机制,它是通过Web Host以及Self Host的寄宿的宿主方式来提供一个请求-响应的运行环境.二者都是将请求和 ...
- iOS UISearchDisplayController学习笔记
UISearchDisplayController和UISearchBar一起使用用来管理UISearchBar和搜索结果的展示.UISearchDisplayController提供了显示搜索结果的 ...
- 关于cocos2dx导入安卓项目至eclipse的诸多问题
看视频实在是有点蛋疼,尽管我也想在苹果上做,可是奈何自己是一个小屌丝,根本买不起高富帅的装备.所以仅仅能硬着头皮去处理win以下的问题. 在把用C++语言编写的cocos2dx项目编译编译完毕之后,导 ...
- Oracle 11g+oracle客户端(32位)+PL/SQL develepment的安装配置
之前一直想学Oracle,可是就是安装配置Oracle一直未成功,让人很苦恼,特别是什么监听器什么的,一直没搞明白,弄了整整一天都没弄出来,上网查资料后发现资料上大多数都是参差不齐,不太详细明了,尝试 ...
- android模拟器与PC的端口映射(转)
阅读目录 一.概述 二.实现步骤 回到顶部 一.概述 Android系统为实现通信将PC电脑IP设置为10.0.2.2,自身设置为127.0.0.1,而PC并没有为Android模拟器系统指定IP,所 ...