您好,登錄后才能下訂單哦!
這篇文章主要介紹“mybatis實(shí)體類字段獲取不到值怎么解決”,在日常操作中,相信很多人在mybatis實(shí)體類字段獲取不到值怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”mybatis實(shí)體類字段獲取不到值怎么解決”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
由于前期設(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)致了字段獲取不到值!
由于在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í)用的文章!
免責(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)容。