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 ...
随机推荐
- XCL-Charts画一个图(CurveChart)
情节线图与往常不同的是,它是一个比较特殊线位置计算.所以我得到一个单独的类.相同.只需要输入数据源的基类, 加,控制要添加的.你可以画出你自己主动设置按照预期的效果. 代码: //图基类 chart ...
- QlikView线图高亮选择尺寸
作为标题,如今,学生问我一个问题.尺寸Month.expression它是Count(Id). 这个图是一个折线图,不管你选择哪个月的其他下拉列表,销售量.由于Expression里面是这样写的 Co ...
- ACM字符串处理算法经典:字符串搜索
语法:result=strfind(char str[],char key[]); 参数: str[]:在这个源字符串查找操作 key[]:搜索字符串.不能为空字符串 回报值: 假设查找成功. ...
- HDU 3081 Marriage Match II(二分法+最大流量)
HDU 3081 Marriage Match II pid=3081" target="_blank" style="">题目链接 题意:n个 ...
- PHP微信SDK——Zebra-Wechat
Zebra-Wechat 微信SDK 眼下处于开发状态,眼下实现了下面功能: 接收微信server推送信息,对推送信息类型进行识别 微信APIclient封装(用户管理.用户组管理.客服管理.自己定义 ...
- android 拍照注意问题
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); startActivityForResult(intent, reqCode) ...
- mysql 修改[取消]timestamp的自动更新
创建自动更新的 timestamp (插入或修改时 uptime都会自动更新) CREATE TABLE `hello` ( `id` int(11) NOT NULL, `uptime` times ...
- DevExpress Report 其他常用设计技巧
原文:DevExpress Report 其他常用设计技巧 1 设置默认的打印纸张及页边距 选择Report-打开属性窗口,设置默认边距(Margins)和默认纸张(PaperKind). 2 修改R ...
- NSOJ Minimum Transport Cost
These are N cities in Spring country. Between each pair of cities there may be one transportation tr ...
- 大数据系列修炼-Scala课程04
Scala中继承实现:超类的构造.字段重写.方法重写 关于超类的构建:超类可以在子类没有位置的限制,可以在子类中调用父类的方法 类中字段重写:在重写字段前面加一个override就可以重新赋值 类中方 ...