溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mybatis實(shí)體類字段獲取不到值怎么解決

發(fā)布時(shí)間:2021-11-26 10:28:49 來源:億速云 閱讀:818 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“mybatis實(shí)體類字段獲取不到值怎么解決”,在日常操作中,相信很多人在mybatis實(shí)體類字段獲取不到值怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”mybatis實(shí)體類字段獲取不到值怎么解決”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

mybatis實(shí)體類字段大小寫問題 字段獲取不到值

由于前期設(shè)計(jì)問題,項(xiàng)目中需要用到的一個(gè)字段 rootpath,所以我再實(shí)體層加了這么一個(gè)字段。

mybatis實(shí)體類字段獲取不到值怎么解決

然后,我在前臺(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實(shí)體類字段獲取不到值怎么解決

推斷

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);
            }
        };
    }
}

到此,關(guān)于“mybatis實(shí)體類字段獲取不到值怎么解決”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI