自己的List的TypeHandler案例

package cn.***.api.mappers.handler;

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import cn.***.api.model.WechatTemplate;
import oracle.jdbc.OracleConnection;
import oracle.sql.ARRAY;
import oracle.sql.ArrayDescriptor;
import oracle.sql.STRUCT;
import oracle.sql.StructDescriptor;

public class WechatTemplateArrayTypeHandler extends BaseTypeHandler {
    private final StringORA_OBJ_TYP="TYP_WECHAT_TEMPLATE";
    private final String ORA_TAB_TYP="TAB_WECHAT_TEMPLATE";

    @Override
    public void setNonNullParameter(PreparedStatement ps,int i, Object o, JdbcType jdbcType) throws SQLException {
        Connectionconn=null;
        try{
            if(null!=o) {
                @SuppressWarnings("unchecked")
                List list= (ArrayList)o;
                conn=ps.getConnection();
                if(conn.isWrapperFor(OracleConnection.class)) {
                    conn=conn.unwrap(OracleConnection.class);
                    ARRAY array= getArray(conn,ORA_OBJ_TYP,ORA_TAB_TYP,list);
                    ps.setArray(i,array);
                }
            }
        }catch(ClassNotFoundException e) {
            e.printStackTrace();
        }catch(Exception e) {
            e.printStackTrace();
        }
    }

    @Override
    public Object getNullableResult(ResultSet rs, String columnName)throws SQLException {
        return null;
    }

    @Override
    public Object getNullableResult(ResultSet rs,int columnIndex)throws SQLException {
        return null;
    }

    @Override
    public Object getNullableResult(CallableStatement cs,int columnIndex)throws SQLException {
        retur null;
    }

    private ARRAY getArray(Connection con, String OracleObj, String Oraclelist, List listData) throws Exception{
        ARRAY array=null;
        ArrayDescriptor desc= ArrayDescriptor.createDescriptor(Oraclelist,con);
        STRUCT[] structs=new STRUCT[listData.size()];
        if(list Data!=null&&listData.size() > 0) {
            StructDescriptor structdesc=new StructDescriptor(OracleObj,con);
            for(int i= 0;i < listData.size(); i++) {
                Object[] result= {
                    listData.get(i).getId(),
                    listData.get(i).getTemplateId(),
                    listData.get(i).getTitle(),
                    listData.get(i).getPrimaryIndustry(),
                    listData.get(i).getDeputyIndustry(),
                    listData.get(i).getParamNumber(),
                    listData.get(i).getContent(),
                    listData.get(i).getExample(),
                    listData.get(i).getStatus() 
                };
                structs[i] =new STRUCT(structdesc,con,result);
            }
            array=new ARRAY(desc,con,structs);
        }else{
            array=new ARRAY(desc,con,structs);
        }
        return array;
    }

}
TypeHandler是MyBatis框架中的一个重要组件,用于处理Java对象与数据库字段之间的类型转换。在使用TypeHandler时,需要在插入数据和对返回结果进行处理时标识需要使用的TypeHandler。可以通过配置javaType和jdbcType属性或直接配置typeHandler属性来进行标识。\[1\] 在插入数据时,可以使用<insert>标签来标识使用指定的TypeHandler进行处理。例如,可以在插入语句中使用typeHandler属性来指定TypeHandler的类名,如:#{hobbys,typeHandler=com.sankuai.lkl.typeHandler.ListTypeHandler}。\[1\] 自定义TypeHandler完成后,需要在mybatis-config.xml文件中进行配置,将其注册到MyBatis中。可以使用<typeHandlers>标签来配置TypeHandler,指定jdbcType、javaTypehandler属性。例如:<typeHandler jdbcType="VARCHAR" javaType="list" handler="com.sankuai.lkl.typeHandler.ListTypeHandler"/>。\[2\] 关于javaType的指定,可以通过类型处理器的泛型来让MyBatis知道该类型处理器处理的Java类型。此外,还可以通过在类型处理器的配置元素上增加javaType属性或在类型处理器的类上增加@MappedTypes注解来指定与其关联的Java类型列表。如果在javaType属性中也同时指定,则注解上的配置将被忽略。\[3\] #### 引用[.reference_title] - *1* *2* [Mybatis之TypeHandler使用教程](https://blog.csdn.net/jokeMqc/article/details/81326109)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【Mybatis】类型处理器TypeHandler的作用与自定义](https://blog.csdn.net/weixin_45489731/article/details/126317853)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值