No Dialect mapping for JDBC type解决方法

本文介绍了解决SSH架构中使用BigDecimal类型时遇到的问题。通过自定义MySQL方言类并注册BigDecimal类型,使得Hibernate能够正确映射数据库中的Decimal字段。

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

在ssh架构中使用mysql数据库,在javaBean中使用属性:BigDecimal,hibernate无法映射此类型的对象。

在数据库中此字段必须为Decimal类型。 会报No Dialect mapping for JDBC type:-1

为让hibernate知道此类型。

必须一下做法:

package com.quduan;

import java.sql.Types;   
import org.hibernate.Hibernate;   
import org.hibernate.dialect.MySQLDialect; 

public class ZJCMySQLDialect extends MySQLDialect{
 
  public ZJCMySQLDialect () {   
         super();   
         registerHibernateType(Types.DECIMAL, Hibernate.BIG_DECIMAL.getName());  
         registerHibernateType(-1, Hibernate.STRING.getName());
     }   

}


 

修改:

<prop key="hibernate.dialect">
     com.quduan.ZJCMySQLDialect
    </prop>


 

 这样就可以支持BigDecimal类型了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值