關於blob與流互轉的問題

網上有好多blob與byte[]互相轉換的代碼,但是很難找到流直接寫入到數據庫的。顯然流寫入效率更高,內存佔用更少(不需要把所有數據放到內存裏面),以下便是代碼(基於Spring Data JPA的版本的 JDBC的話實現類同)

import org.hibernate.Hibernate;
import org.hibernate.Session;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;
import javax.persistence.EntityManager;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Blob;
import java.sql.SQLException;

@Component
public class BlobUtil {
    private final static Logger logger = LoggerFactory.getLogger(BlobUtil.class);
    @Autowired
    private EntityManager entityManager;

    private Session session;

    @PostConstruct
    public void init() {
        entityManager = entityManager.getEntityManagerFactory().createEntityManager();
        session = entityManager.unwrap(Session.class);
    }

    public InputStream getStream(Blob blob) {
        try {
            if (blob != null) {
                return blob.getBinaryStream();
            }
        } catch (SQLException e) {
            logger.error("轉化出現錯誤 {}", e);
        }
        return null;
    }

    public Blob getBlob(InputStream inputStream) {
        if (inputStream != null) {
            try {
                return Hibernate.getLobCreator(session).createBlob(inputStream, inputStream.available());
            } catch (IOException e) {
                logger.error("轉化出現錯誤 {}", e);
            }
        }
        return null;
    }
}

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章