很多网站系统都是把上传的图片文件保存到服务器目录,但有些需求必须要把图片保存到数据库才行,例如两个系统共享一个数据库的情况下,就只能把图片文件上传保存到数据库,通过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用于保存大的文本文件。