国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mybatis簡(jiǎn)單resultMap使用詳解

瀏覽:5日期:2023-10-19 13:15:17

Mybatis的介紹以及使用:http://www.mybatis.org/mybatis-3/zh/index.html

mybatis是一個(gè)半自動(dòng)的ORM(Object Relational Mapping)框架,需要手動(dòng)配置一些SQL語(yǔ)句或者注解,相對(duì)來(lái)說(shuō)Mybatis留給程序員操作的空間靈活度更高,通常需要手動(dòng)配置一些東西完成OR映射。當(dāng)數(shù)據(jù)庫(kù)表中的字段 和 POJO實(shí)體類(lèi)不匹配時(shí),這是就需要程序員手動(dòng)完成字段的映射。

mybatis-config.xml配置文件

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE configurationPUBLIC '-//mybatis.org//DTD Config 3.0//EN''http://mybatis.org/dtd/mybatis-3-config.dtd'><configuration> <properties resource='db.properties'/> <settings><!-- 使用日志進(jìn)行幫忙查看 --><setting name='logImpl' value='STDOUT_LOGGING'/> </settings> <typeAliases><!-- 取個(gè)別名 --><typeAlias type='com.pojo.User' alias='user'/> </typeAliases> <environments default='development'><environment id='development'> <transactionManager type='JDBC'/> <dataSource type='POOLED'><property name='driver' value='${driver}'/><property name='url' value='${url}'/><property name='username' value='${username}'/><property name='password' value='${password}'/> </dataSource></environment> </environments> <mappers><mapper resource='com/dao/UserMapper.xml'/> </mappers></configuration>

mybatisUtil加載工具類(lèi)

import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;import java.io.InputStream;public class mybatisUtil { private static SqlSessionFactory sqlSessionFactory = null; static {try { String resource = 'mybatis-config.xml'; InputStream in = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);} catch (IOException e) { e.printStackTrace();} } public static SqlSession getSqlsession(){return sqlSessionFactory.openSession(); }}

POJO實(shí)體類(lèi)User,為了方便簡(jiǎn)單實(shí)用Lombok注解,減少一些代碼。

mybatis簡(jiǎn)單resultMap使用詳解

package com.pojo;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;@Data //各種get / set方法 Tostring...@AllArgsConstructor //全參構(gòu)造@NoArgsConstructor //無(wú)參構(gòu)造public class User { private int id;//對(duì)應(yīng)數(shù)據(jù)庫(kù)中的id private String username;//對(duì)應(yīng)數(shù)據(jù)庫(kù)中的name private String password;//對(duì)應(yīng)數(shù)據(jù)庫(kù)中的pwd}

接口方法與對(duì)應(yīng)的xml配置文件

package com.dao;import com.pojo.User;import java.util.List;public interface UserMapper { List<User> getUserList();}

xml映射

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapperPUBLIC '-//mybatis.org//DTD Mapper 3.0//EN''http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.dao.UserMapper'><select resultType='user'> select *from user;</select></mapper>

1. POJO實(shí)體類(lèi) 和 數(shù)據(jù)表字段不匹配

@Testpublic void test1(){ SqlSession session = mybatisUtil.getSqlsession(); UserMapper mapper = session.getMapper(UserMapper.class); List<User> list = mapper.getUserList(); for (User user : list) {System.out.println(user.toString()); } session.close();}

POJO實(shí)體類(lèi)中有兩個(gè)字段和數(shù)據(jù)庫(kù)的字段不匹配,最后獲得結(jié)果的時(shí)對(duì)于匹配失敗的屬性會(huì)產(chǎn)生null空值。使用輸出日志進(jìn)行幫忙很容易看到區(qū)別。

mybatis簡(jiǎn)單resultMap使用詳解

簡(jiǎn)單的解決方案:就是SQL語(yǔ)句查詢時(shí)給查詢字段使用重命名。

select id, name as username, pwd as password from user

mybatis簡(jiǎn)單resultMap使用詳解

2. resultMap解決屬性 - 字段不匹配問(wèn)題

上面這種解決方案是能夠解決問(wèn)題的,但是有點(diǎn)冗余本身就要查全部的信息用的 * 做通配。這么一改需要每個(gè)字段都列出來(lái),然后對(duì)極個(gè)別的字段進(jìn)行取別名。試想一下當(dāng)數(shù)據(jù)表中有幾十個(gè)字段呢?而真正需要取別名的字段只有1 - 2個(gè)呢?因此mybatis提供了一個(gè)強(qiáng)大的機(jī)制resultMap結(jié)果集映射來(lái)解決這個(gè)問(wèn)題。

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapperPUBLIC '-//mybatis.org//DTD Mapper 3.0//EN''http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.dao.UserMapper'><!-- 1. id可以認(rèn)為是定義方法名,整個(gè)resultMap是一個(gè)映射方法,調(diào)用這個(gè)方法就可以完成這個(gè)映射。 2. type是實(shí)體類(lèi)的名稱(chēng) --> <resultMap type='user'> <!-- column 是數(shù)據(jù)庫(kù)字段名 property是實(shí)體類(lèi)屬性名 --><result column='name' property='username'/><result column='pwd' property='password'/> </resultMap> <select resultMap='FieldMap'>select *from user </select></mapper>

mybatis簡(jiǎn)單resultMap使用詳解

resultMap標(biāo)簽的解釋?zhuān)?/p> id可以認(rèn)為定義方法的名稱(chēng),下面select中的resultMap傳入id的值就相當(dāng)于使用這個(gè)方法完成映射。 type是實(shí)體類(lèi)名 column對(duì)應(yīng)數(shù)據(jù)庫(kù)中的字段 property是實(shí)體類(lèi)的屬性。

到此這篇關(guān)于mybatis簡(jiǎn)單resultMap使用詳解的文章就介紹到這了,更多相關(guān)mybatis resultMap使用內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 伊宁县| 宾川县| 济南市| 廉江市| 吉安县| 潼关县| 靖远县| 大庆市| 安乡县| 安溪县| 大港区| 博乐市| 九龙坡区| 阳江市| 潮州市| 滨州市| 镇远县| 那坡县| 云龙县| 武宣县| 商都县| 哈密市| 广河县| 鸡泽县| 西平县| 太仓市| 健康| 铜陵市| 屯昌县| 三台县| 马龙县| 屏边| 鄂温| 嵩明县| 扬中市| 钦州市| 芦溪县| 富川| 佛学| 灯塔市| 故城县|