最近在項目開發中,使用spring boot+mybatis的架構,資料庫設計主鍵id時定義為bigint類型,使用mybatis的自動生成代碼後沒注意,主鍵在pojo裡的類型為Long。查詢時擷取的對象清單取出的數值沒有問題,但轉為json傳到前端後,id的資料始終不是資料庫查出來的那個。
資料庫表結構設計:

AbumTip類:
根據外鍵abum_id在資料庫中查詢的結果:
Controller查到的結果:
chrome浏覽器preview結果:
可以看到abumId(對應表abum_id)和tipId(對應表中tip_id)查詢到的Long類型的資料都不對。
解決的方法:
方法一:重新生成pojo對象,将所有資料庫類型為bigint都映射成String類型。
方法二:對于使用springboot,則增加配置代碼:
package com.gj.app.config;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import java.util.List;
@EnableWebMvc
@Configuration
public class WebDataConvertConfig extends WebMvcConfigurerAdapter {
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
MappingJackson2HttpMessageConverter jackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter();
ObjectMapper objectMapper = new ObjectMapper();
/**
* 序列換成json時,将所有的long變成string
* 因為js中得數字類型不能包含所有的java long值
*/
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
objectMapper.registerModule(simpleModule);
jackson2HttpMessageConverter.setObjectMapper(objectMapper);
converters.add(jackson2HttpMessageConverter);
}
}
方法三: 在spring MVC中:
增加類:
其中LongToStringJsonConverter為自定義轉換器
public class LongToStringJsonConverter extends ObjectMapper {
/**
*
*/
private static final long serialVersionUID = 1683531771040674386L;
@Override
public ObjectMapper registerModule(Module module) {
SimpleModule simpleModule = new SimpleModule();
simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
return super.registerModule(simpleModule);
}
}
配置到springmvc檔案中即可
<mvc:annotation-driven conversion-service="conversionService">
<mvc:message-converters>
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="objectMapper">
<!-- <bean class="com.fasterxml.jackson.databind.ObjectMapper"> -->
<bean class="mypackage.LongToStringAdapter">
<property name="dateFormat">
<bean class="java.text.SimpleDateFormat">
<constructor-arg type="java.lang.String" value="yyyy-MM-dd HH:mm:ss" />
</bean>
</property>
</bean>
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>