亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2021年11月26日 08:46:36   作者:yangniceyang  
這篇文章主要介紹了mybatis?實(shí)體類字段大小寫問題?字段獲取不到值的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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)文章

  • java反編譯工具Bytecode-Viewer分享

    java反編譯工具Bytecode-Viewer分享

    這篇文章主要介紹了java反編譯工具Bytecode-Viewer分享,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 使用@Service注解出現(xiàn)No bean named 'xxxx' available]錯(cuò)誤的解決

    使用@Service注解出現(xiàn)No bean named 'xxxx'&

    這篇文章主要介紹了使用@Service注解出現(xiàn)No bean named 'xxxx' available]錯(cuò)誤的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • spring+shiro 整合實(shí)例代碼詳解

    spring+shiro 整合實(shí)例代碼詳解

    本文通過實(shí)例代碼給大家介紹spring+shiro 整合的過程,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-10-10
  • springboot項(xiàng)目打包鏡像方式以及區(qū)分環(huán)境打包的方法

    springboot項(xiàng)目打包鏡像方式以及區(qū)分環(huán)境打包的方法

    本文主要介紹了springboot項(xiàng)目打包鏡像方式以及區(qū)分環(huán)境打包的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • Spring?Boot常用的參數(shù)驗(yàn)證技巧和使用方法

    Spring?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(入門)

    新手小白學(xué)JAVA 日期類Date SimpleDateFormat Calendar(入門)

    本文主要介紹了JAVA 日期類Date SimpleDateFormat Calendar,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • idea mybatis配置log4j打印sql語(yǔ)句的示例

    idea mybatis配置log4j打印sql語(yǔ)句的示例

    本篇文章主要介紹了idea mybatis配置log4j打印sql語(yǔ)句的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • Idea導(dǎo)入eureka源碼實(shí)現(xiàn)過程解析

    Idea導(dǎo)入eureka源碼實(shí)現(xiàn)過程解析

    這篇文章主要介紹了Idea導(dǎo)入eureka源碼實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • spring mvc實(shí)現(xiàn)文件上傳并攜帶其他參數(shù)的示例

    spring mvc實(shí)現(xiàn)文件上傳并攜帶其他參數(shù)的示例

    本篇文章主要介紹了spring mvc實(shí)現(xiàn)文件上傳并攜帶其他參數(shù)的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02
  • 詳解Jackson的基本用法

    詳解Jackson的基本用法

    Java生態(tài)圈中有很多處理JSON和XML格式化的類庫(kù),Jackson是其中比較著名的一個(gè)。雖然JDK自帶了XML處理類庫(kù),但是相對(duì)來說比較低級(jí),使用本文介紹的Jackson等高級(jí)類庫(kù)處理起來會(huì)方便很多
    2021-06-06

最新評(píng)論