mybatis?實(shí)體類字段大小寫問題?字段獲取不到值的解決
mybatis實(shí)體類字段大小寫問題 字段獲取不到值
由于前期設(shè)計(jì)問題,項(xiàng)目中需要用到的一個(gè)字段 rootpath,所以我再實(shí)體層加了這么一個(gè)字段。
然后,我在前臺(tái)向后臺(tái)傳數(shù)據(jù)的時(shí)候,這個(gè)rootpath一直都獲取不到值。經(jīng)過排查對(duì)比,發(fā)現(xiàn)我寫的set和get方法名稱后面的RootPath 中的P字母大寫導(dǎo)致的。
解決辦法
將set和get方法后面的P改為小寫p就可以了
推斷
mybatis認(rèn)為rootpath是一個(gè)單詞,但是我錯(cuò)誤的認(rèn)為了是兩個(gè)單詞,然后再寫set和get的時(shí)候給P大寫了,所以導(dǎo)致了字段獲取不到值!
踩坑mybatis 轉(zhuǎn)換大小寫問題
由于在Windows環(huán)境下MySQL數(shù)據(jù)庫(kù)不嚴(yán)格區(qū)分大小寫,所以我們?cè)趯?duì)數(shù)據(jù)庫(kù)的表和字段進(jìn)行命名時(shí)兩個(gè)單詞之間都是使用下劃線“_”的,比如“user_name”。但是,我們?cè)陧?xiàng)目開發(fā)時(shí),為了遵守代碼規(guī)范,實(shí)體類中的屬性采用的都是駝峰式命名。這樣,MyBatis可能就會(huì)報(bào)錯(cuò)沒有該屬性的get和set方法。
解決方法
1.使用resultMap
通過resultMap中的column值(數(shù)據(jù)庫(kù)字段名)和property值(實(shí)體類屬性名)進(jìn)行一一映射。
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.mapper.UserMapper"> <resultMap id="BaseResultMap" type="com.domain.User"> <id column="id" jdbcType="INTEGER" property="id" /> <result column="user_name" jdbcType="VARCHAR" property="userName" /> <result column="password" jdbcType="VARCHAR" property="password" /> </resultMap> <select id="xxx" parameterType="xxx" resultMap="BaseResultMap" > ...... </select>
2.對(duì)MyBatis進(jìn)行配置:
(1)在mybatis-config.xml配置文件中添加以下代碼:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <configuration> <!-- 配置mybatis自動(dòng)轉(zhuǎn)換為駝峰命名 --> <settings> <setting name="mapUnderscoreToCamelCase" value="true" /> </settings> </configuration>
(2) 在application.yml文件中進(jìn)行配置:
#mybatis配置 mybatis: configuration: map-underscore-to-camel-case: true
其中的map-underscore-to-camel-case也可以寫成mapUnderscoreToCamelCase(未嘗試),然后MyBatis的xml文件中直接使用對(duì)應(yīng)的實(shí)體類來接收數(shù)據(jù)。
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.mapper.UserMapper"> <select id="xxx" parameterType="xxx" resultType="User" > ...... </select>
第(1)種方式和第(2)種方式同時(shí)配置時(shí),第(2)種方式的優(yōu)先級(jí)更高。
3.自定義配置類的方式配置:給容器中添加一個(gè)ConfigurationCustomizer。
@Configuration public class MyBatisConfig { @Bean public ConfigurationCustomizer configurationCustomizer() { return new ConfigurationCustomizer() { @Override public void customize(org.apache.ibatis.session.Configuration configuration) { configuration.setMapUnderscoreToCamelCase(true); } }; } }
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用@Service注解出現(xiàn)No bean named 'xxxx'&
這篇文章主要介紹了使用@Service注解出現(xiàn)No bean named 'xxxx' available]錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08springboot項(xiàng)目打包鏡像方式以及區(qū)分環(huán)境打包的方法
本文主要介紹了springboot項(xiàng)目打包鏡像方式以及區(qū)分環(huán)境打包的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-03-03Spring?Boot常用的參數(shù)驗(yàn)證技巧和使用方法
Spring Boot是一個(gè)使用Java編寫的開源框架,用于快速構(gòu)建基于Spring的應(yīng)用程序,這篇文章主要介紹了Spring?Boot常用的參數(shù)驗(yàn)證技巧和使用方法,需要的朋友可以參考下2023-09-09新手小白學(xué)JAVA 日期類Date SimpleDateFormat Calendar(入門)
本文主要介紹了JAVA 日期類Date SimpleDateFormat Calendar,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10idea mybatis配置log4j打印sql語(yǔ)句的示例
本篇文章主要介紹了idea mybatis配置log4j打印sql語(yǔ)句的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01Idea導(dǎo)入eureka源碼實(shí)現(xiàn)過程解析
這篇文章主要介紹了Idea導(dǎo)入eureka源碼實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08spring mvc實(shí)現(xiàn)文件上傳并攜帶其他參數(shù)的示例
本篇文章主要介紹了spring mvc實(shí)現(xiàn)文件上傳并攜帶其他參數(shù)的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02