Mybatis存放blob数据

一、存储图片

1.数据库表

2.PicMapper.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mapper.PicMapper">
  <resultMap id="BaseResultMap" type="com.entity.Pic">
    <id column="id" property="id" jdbcType="INTEGER" />
    <result column="name" property="name" jdbcType="LONGVARCHAR" />
    <result column="photo" property="photo" typeHandler="org.apache.ibatis.type.BlobTypeHandler" />
  </resultMap>

  <sql id="Example_Where_Clause">
    <where>
      <foreach collection="oredCriteria" item="criteria" separator="or">
        <if test="criteria.valid">
          <trim prefix="(" prefixOverrides="and" suffix=")">
            <foreach collection="criteria.criteria" item="criterion">
              <choose>
                <when test="criterion.noValue">
                  and ${criterion.condition}
                </when>
                <when test="criterion.singleValue">
                  and ${criterion.condition} #{criterion.value}
                </when>
                <when test="criterion.betweenValue">
                  and ${criterion.condition} #{criterion.value} and #{criterion.secondValue}
                </when>
                <when test="criterion.listValue">
                  and ${criterion.condition}
                  <foreach close=")" collection="criterion.value" item="listItem" open="(" separator=",">
                    #{listItem}
                  </foreach>
                </when>
              </choose>
            </foreach>
          </trim>
        </if>
      </foreach>
    </where>
  </sql>
  <sql id="Base_Column_List">
    id, name, photo
  </sql>
  <select id="selectByPrimaryKey" parameterType="java.lang.Integer" resultMap="BaseResultMap">
    select 
    <include refid="Base_Column_List" />
    from pic
    where id = #{id,jdbcType=INTEGER}
  </select>

  <insert id="insert" parameterType="cn.piesat.business.entity.Pic">
    insert into pic (id, name, photo
      )
    values (#{id,jdbcType=INTEGER}, #{name,jdbcType=LONGVARCHAR}, #{photo,jdbcType=LONGVARBINARY}
      )
  </insert>

</mapper>

3.PicMapper.java

package com.mapper;
import com.entity.Pic;
import org.apache.ibatis.annotations.Mapper;

@Mapper
public interface PicMapper {

    int insert(Pic record);

    Pic selectByPrimaryKey(Integer id);

}

4.PicService.java

package com.services;
import cn.piesat.business.entity.Pic;
import cn.piesat.business.mapper.PicMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
@Slf4j
@Service
public class PicService  {

    @Autowired
    private PicMapper picMapper;

    public void addPic(Pic pic) {
        int insert = picMapper.insert(pic);
        System.out.println(insert);
    }

    public Pic getPic(Integer id) {
        Pic pic = picMapper.selectByPrimaryKey(id);
        System.out.println(pic.getPhoto());
        return  pic;
    }

    public static void main(String[] args) throws IOException {
        Pic pic = new Pic();
        pic.setName("111");
        FileInputStream fis = new FileInputStream("D:\\twitter.png");
        byte[] bytes = FileCopyUtils.copyToByteArray(fis);
        pic.setPhoto(bytes);
        PicService picService = new PicService();
        picService.addPic(pic);
        Pic pic1 = picService.getPic(1);

        File file = new File("D:\\11.png");
        FileOutputStream fos = new FileOutputStream(file);
        FileCopyUtils.copy(pic1.getPhoto(), fos);
    }
}

5.效果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值