解决 js在对长度较长的长整型数据进行处理时, 会损失精度, 从而导致提交的id和数据库中的id不一致。(long类型)

文章讲述了在JavaScript中处理长整型数据时可能会遇到的精度丢失问题,并提出了将ID数据类型转换为字符串以避免精度损失的解决方案。通过自定义JacksonObjectMapper,扩展SpringMVC的MappingJackson2HttpMessageConverter,确保在序列化和反序列化过程中,长整型和特定日期类型以字符串形式处理,从而解决问题。
摘要由CSDN通过智能技术生成
问题:

     js在对长度较长的长整型数据进行处理时, 会损失精度, 从而导致提交的id和数据库中的id不一致。 

解决思路:

   让js处理的ID数据类型为字符串类型即可, 这样就不会损失精度了。让返回的json格式数据库中, long类型的属性, 不直接转换为数字类型, 转换为字符串类型就可以解决这个问题了

代码修复:

    由于在SpringMVC中, 将Controller方法返回值转换为json对象, 是通过jackson来实现的, 涉及到SpringMVC中的一个消息转换器MappingJackson2HttpMessageConverter, 所以我们要解决这个问题, 就需要对该消息转换器的功能进行拓展。

具体实现步骤:

1). 提供对象转换器JacksonObjectMapper,基于Jackson进行Java对象到json数据的转换(资料中已经提供,直接复制到项目中使用)

2). 在WebMvcConfig配置类中扩展Spring mvc的消息转换器,在此消息转换器中使用提供的对象转换器进行Java对象到json数据的转换

1). 引入JacksonObjectMapper

/**
 * 对象映射器:基于jackson将Java对象转为json,或者将json转为Java对象
 * 将JSON解析为Java对象的过程称为 [从JSON反序列化Java对象]
 * 从Java对象生成JSON的过程称为 [序列化Java对象到JSON]
 */
public class JacksonObjectMapper extends ObjectMapper {
    public static final String DEFAULT_DATE_FORMAT = "yyyy-MM-dd";
    public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss";
    public static final String DEFAULT_TIME_FORMAT = "HH:mm:ss";
    public JacksonObjectMapper() {
        super();
        //收到未知属性时不报异常
        this.configure(FAIL_ON_UNKNOWN_PROPERTIES, false);
        //反序列化时,属性不存在的兼容处理
        this.getDeserializationConfig().withoutFeatures(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);

        SimpleModule simpleModule = new SimpleModule()
                .addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
                .addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
                .addDeserializer(LocalTime.class, new LocalTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)))

                .addSerializer(BigInteger.class, ToStringSerializer.instance)
                .addSerializer(Long.class, ToStringSerializer.instance)

                .addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
                .addSerializer(LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
                .addSerializer(LocalTime.class, new LocalTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)));
        //注册功能模块 例如,可以添加自定义序列化器和反序列化器
        this.registerModule(simpleModule);
    }
}

  该自定义的对象转换器, 主要指定了, 在进行json数据序列化及反序列化时, LocalDateTime、LocalDate、LocalTime的处理方式, 以及BigInteger及Long类型数据,直接转换为字符串。

2). 在WebMvcConfig(实现WebMvcConfigurationSupport接口的类)中重写方法extendMessageConverters

/**
 * 扩展mvc框架的消息转换器
 * @param converters
 */
@Override
protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
    log.info("扩展消息转换器...");
    //创建消息转换器对象
    MappingJackson2HttpMessageConverter messageConverter = new MappingJackson2HttpMessageConverter();
    //设置对象转换器,底层使用Jackson将Java对象转为json
    messageConverter.setObjectMapper(new JacksonObjectMapper());
    //将上面的消息转换器对象追加到mvc框架的转换器集合中
    converters.add(0,messageConverter);
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是各种数据库的常见数据类型及其精度长度和适用场景: 1. SQL Server 数据类型: - 整型:int(4字节,-2,147,483,648 到 2,147,483,647)、bigint(8字节,-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807) - 浮点型:float(4字节,-3.40E+38 到 3.40E+38)、real(8字节,-1.79E+308 到 1.79E+308) - 字符串:char(定字符串,最大长度为8,000)、varchar(可变长度字符串,最大长度为8,000)、text(大文本,最大长度为2GB) - 日期/间:datetime(日期和间,精度为1/300秒)、date(日期,精度为1天)、time(间,精度为100纳秒) - 逻辑型:bit(1位,0或1) 2. Oracle 数据类型: - 整型:number(可变长度,最大38位)、integer(4字节,-2,147,483,648 到 2,147,483,647) - 浮点型:float(4字节,-3.40E+38 到 3.40E+38)、double precision(8字节,-1.79E+308 到 1.79E+308) - 字符串:char(定字符串,最大长度为2,000字节)、varchar2(可变长度字符串,最大长度为4,000字节)、clob(大文本,最大长度为4GB) - 日期/间:date(日期和间,精度为1秒)、timestamp(日期和间,精度为1纳秒) - 逻辑型:boolean(1位,true或false) 3. MySQL 数据类型: - 整型:int(4字节,-2,147,483,648 到 2,147,483,647)、bigint(8字节,-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807) - 浮点型:float(4字节,-3.40E+38 到 3.40E+38)、double(8字节,-1.79E+308 到 1.79E+308) - 字符串:char(定字符串,最大长度为255字节)、varchar(可变长度字符串,最大长度为65,535字节)、text(大文本,最大长度为4GB) - 日期/间:datetime(日期和间,精度为1秒)、date(日期,精度为1天)、time(间,精度为1秒) - 逻辑型:boolean(1位,true或false) 以上是各种数据库的常见数据类型及其精度长度和适用场景,希望能对你有所帮助。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值