### Error querying database. Cause: java.lang.IllegalArgumentException:

本文介绍了一种解决数据库查询中出现的支付状态枚举类型异常的方法。通过在配置文件中添加枚举类型处理器,并定义支付状态枚举类型,确保数据库与应用之间的正确映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

异常:

### Error querying database.  Cause: java.lang.IllegalArgumentException: No enum constant com.baoogu.scm.enums.payment.PaymentTypeEnum.10

解决办法:

sqlmap-config.xml

添加:

<typeHandler handler="com.baoogu.scm.core.orm.mybatis.EnumDataTypeHandler" javaType="com.baoogu.scm.enums.payment.PaymentTypeEnum"/>


public enum PaymentStatusEnum implements EnumDataType {
	/**
	 * UNPAYMENT("待付款", 10)
	 */
	UNPAYMENT("待付款", 10),

	/**
	 * SUCCESS_PAYMENT("付款成功", 20)
	 */
	SUCCESS_PAYMENT("付款成功", 20),
	/**
	 * FAIL_PAYMENT("付款失败",30)
	 */
	FAIL_PAYMENT("付款失败",30);

	private String display;
	private int code;

	// 构造方法
	private PaymentStatusEnum(String display, int code) {
		this.display = display;
		this.code = code;
	}

	public int getCode() {
		return this.code;
	}

	public String getValue() {
		return name();
	}

	/**
	 * 根据code获得名称
	 *
	 * @param code
	 * @return
	 */
	public static PaymentStatusEnum fromCode(int code) {
		PaymentStatusEnum[] codes = PaymentStatusEnum.values();
		for (PaymentStatusEnum state : codes) {
			if (state.getCode() == code) {
				return state;
			}
		}
		return null;
	}

	// 覆盖方法
	@Override
	public String toString() {
		return this.display;
	}

	public String getDisplay() {
		return display;
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值