国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

mybatis簡單resultMap使用詳解

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

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

mybatis是一個半自動的ORM(Object Relational Mapping)框架,需要手動配置一些SQL語句或者注解,相對來說Mybatis留給程序員操作的空間靈活度更高,通常需要手動配置一些東西完成OR映射。當數據庫表中的字段 和 POJO實體類不匹配時,這是就需要程序員手動完成字段的映射。

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><!-- 使用日志進行幫忙查看 --><setting name='logImpl' value='STDOUT_LOGGING'/> </settings> <typeAliases><!-- 取個別名 --><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加載工具類

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實體類User,為了方便簡單實用Lombok注解,減少一些代碼。

mybatis簡單resultMap使用詳解

package com.pojo;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;@Data //各種get / set方法 Tostring...@AllArgsConstructor //全參構造@NoArgsConstructor //無參構造public class User { private int id;//對應數據庫中的id private String username;//對應數據庫中的name private String password;//對應數據庫中的pwd}

接口方法與對應的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實體類 和 數據表字段不匹配

@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實體類中有兩個字段和數據庫的字段不匹配,最后獲得結果的時對于匹配失敗的屬性會產生null空值。使用輸出日志進行幫忙很容易看到區別。

mybatis簡單resultMap使用詳解

簡單的解決方案:就是SQL語句查詢時給查詢字段使用重命名。

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

mybatis簡單resultMap使用詳解

2. resultMap解決屬性 - 字段不匹配問題

上面這種解決方案是能夠解決問題的,但是有點冗余本身就要查全部的信息用的 * 做通配。這么一改需要每個字段都列出來,然后對極個別的字段進行取別名。試想一下當數據表中有幾十個字段呢?而真正需要取別名的字段只有1 - 2個呢?因此mybatis提供了一個強大的機制resultMap結果集映射來解決這個問題。

<?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可以認為是定義方法名,整個resultMap是一個映射方法,調用這個方法就可以完成這個映射。 2. type是實體類的名稱 --> <resultMap type='user'> <!-- column 是數據庫字段名 property是實體類屬性名 --><result column='name' property='username'/><result column='pwd' property='password'/> </resultMap> <select resultMap='FieldMap'>select *from user </select></mapper>

mybatis簡單resultMap使用詳解

resultMap標簽的解釋:

id可以認為定義方法的名稱,下面select中的resultMap傳入id的值就相當于使用這個方法完成映射。 type是實體類名 column對應數據庫中的字段 property是實體類的屬性。

到此這篇關于mybatis簡單resultMap使用詳解的文章就介紹到這了,更多相關mybatis resultMap使用內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 国内精品久久久久久久aa护士 | 欧洲成人在线视频 | 国产精品欧美日韩一区二区 | 国产在线观看精品一区二区三区91 | 最新怡红院全部视频在线 | 一本三道a无线码一区v | 成人三级在线播放线观看 | 国产 一二三四五六 | 88精品视频 | 国产一级成人毛片 | 色综合加勒比 | 伊人热久久 | 国产精品日韩一区二区三区 | 亚洲精品国产精品国自产 | 欧美视频三级 | 午夜性爽视频男人的天堂在线 | 国产精品久久久天天影视香蕉 | 国产精品秦先生手机在线 | 欧美成人影院 | 成年女人免费又黄又爽视频 | ffyybb免费福利视频 | 国内精品久久影视 | 国产精品美女一区二区 | 国产成人在线看 | 全免费毛片在线播放 | 成年午夜性视频免费播放 | 亚洲男人天堂手机版 | 久久久日韩精品国产成人 | 黄网在线免费 | 颜值超高的女神啪啪 | www.日本高清视频.com | 欧美日韩一区二区综合 | 中文字幕在线成人免费看 | 久久综合中文字幕一区二区三区 | 国产成人mv在线观看入口视频 | 日韩特黄特色大片免费视频 | 久久久久久亚洲精品不卡 | 特黄a三级三级三级 | 美国毛片aaa在线播放 | 99视频精品免视3 | 拍拍拍又黄又爽无挡视频免费 |