把图片通过Hibernate持久保存到数据库

很多网站系统都是把上传的图片文件保存到服务器目录,但有些需求必须要把图片保存到数据库才行,例如两个系统共享一个数据库的情况下,就只能把图片文件上传保存到数据库,通过blob字段保存字节数组数据。

 

此例是用mysql进行保存的,实例代码如下:

1、UploadImage.hbm.xml

<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
  <class table="gm_upload_image" name="com.technodex.gp.bo.game.UploadImage">

    <id name="id" type="long" unsaved-value="null" >
            <column name="g_id" not-null="true"/>
            <generator class="identity"/>
     </id>

    <property name="file" type="binary" column="g_file"/>
    <property name="fileType" length="20" type="string" column="g_file_type"/>
    <property name="fileName" length="50" type="string" column="g_file_name"/>
    <property name="fileSize" type="long" column="g_file_size"/>
    <property name="uploadTime" type="timestamp" column="g_upload_time"/>
  </class>
</hibernate-mapping>

 

2、UploadImage.java

public class UploadImage implements Serializable {

    private Long id;
    private byte[] file;
    private String fileType;
    private String fileName;
    private Long fileSize;
    private Date uploadTime;

 

    ...//省略get/set方法

 

}

 

3.Create table

 

DROP TABLE IF EXISTS `gm_upload_image`;
CREATE TABLE `gm_upload_image` (
  `g_id` bigint(20) NOT NULL auto_increment,
  `g_file` blob,
  `g_file_type` varchar(20) default NULL,
  `g_file_name` varchar(50) default NULL,
  `g_file_size` bigint(20) default NULL,
  `g_upload_time` datetime default NULL,
  PRIMARY KEY  (`g_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 

注意byte[]--binary--blob三者的映射,对于blob还有一个clob字段容易混淆,blob一般用于保存二进制图片文件,clob用于保存大的文本文件。

你可能感兴趣的:(Hibernate,数据库,String,upload,File,null)