【问题标题】:How to handle BLOB and CLOB in olingo v2?如何在 olingo v2 中处理 BLOB 和 CLOB?
【发布时间】:2020-07-09 10:52:07
【问题描述】:

Here 有关于如何在 olingo jpa 中处理 BLOB 和 CLOB 的伪代码。我在伪代码中添加了所需的导入:

package me;

import java.sql.Blob;
import java.sql.Clob;
import java.sql.SQLException;

import javax.sql.rowset.serial.SerialException;

import org.apache.olingo.odata2.jpa.processor.api.OnJPAWriteContent;
import org.apache.olingo.odata2.jpa.processor.api.exception.ODataJPARuntimeException;

public class OnDBWriteContent implements OnJPAWriteContent {

    @Override
    public Blob getJPABlob(byte[] binaryData) throws ODataJPARuntimeException {
        try {
            return new JDBCBlob(binaryData);
        } catch (SerialException e) {
            ODataJPARuntimeException.throwException(ODataJPARuntimeException.INNER_EXCEPTION, e);
        } catch (SQLException e) {
            ODataJPARuntimeException.throwException(ODataJPARuntimeException.INNER_EXCEPTION, e);
        }
        return null;
    }

    @Override
    public Clob getJPAClob(char[] characterData) throws ODataJPARuntimeException {
        try {
            return new JDBCClob(new String(characterData));
        } catch (SQLException e) {
            ODataJPARuntimeException.throwException(ODataJPARuntimeException.INNER_EXCEPTION, e);
        }
        return null;
    }
}

唯一的问题是我找不到JDBCBlobJDBCClob 的任何实现。关于如何实现它们或使用某些类的任何建议?

【问题讨论】:

  • 我为 hsqldb 找到了this implementation
  • 您在 JPA 中使用哪个数据库?
  • Mysql 或 MariaDB

标签: java mysql jpa mariadb olingo


【解决方案1】:

如果您使用的是 MySQL,它需要一个额外的 ExceptionInterceptor 以及 Blob 实现。您可以自定义实现 ExceptionInterceptor 并使用它来初始化 Blob 字段。

实现它的代码如下

import java.sql.Blob;
import java.sql.Clob;
import java.util.Properties;

import org.apache.olingo.odata2.jpa.processor.api.OnJPAWriteContent;
import org.apache.olingo.odata2.jpa.processor.api.exception.ODataJPARuntimeException;

import com.mysql.cj.exceptions.ExceptionInterceptor;
import com.mysql.cj.log.Log;

public class CustomOnJPAWriteContent implements OnJPAWriteContent {

    @Override
    public Blob getJPABlob(byte[] binaryData) throws ODataJPARuntimeException {
        return new com.mysql.cj.jdbc.Blob(binaryData, exceptionInterceptor);
    }

    @Override
    public Clob getJPAClob(char[] characterData) throws ODataJPARuntimeException {
        
        return new com.mysql.cj.jdbc.Clob(new String(characterData), exceptionInterceptor);

    }

    ExceptionInterceptor exceptionInterceptor = new ExceptionInterceptor() {

        @Override
        public Exception interceptException(Exception sqlEx) {
            // TODO Auto-generated method stub
            return null;
        }

        @Override
        public ExceptionInterceptor init(Properties props, Log log) {
            // TODO Auto-generated method stub
            return null;
        }

        @Override
        public void destroy() {
            // TODO Auto-generated method stub

        }
    };

}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2012-05-30
    • 2021-01-15
    • 2010-11-04
    • 2018-11-09
    • 2020-02-02
    • 2011-11-25
    • 1970-01-01
    • 2018-11-25
    相关资源
    最近更新 更多