Mybatis --- 获取参数值和查询功能
创始人
2025-05-30 09:00:00
0

一、MyBatis的增删改查

1.1、新增


insert into t_user values(null,'admin','123456',23,'男')

 

1.2、删除


delete from t_user where id = 1

 

1.3、修改


update t_user set username='ybc',password='123' where id = 6

 

1.4、查询一个实体类对象


 

1.5、查询list集合


注意: 查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射关系

resultType:自动映射,用于属性名和表中字段名一致的情况

resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况

 

  

二、MyBatis获取参数值的两种方式

MyBatis获取参数值的两种方式:${}#{}

${} 的本质就是字符串拼接,#{} 的本质就是占位符赋值

${} 使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单 引号

 #{} 使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时, 可以自动添加单引号

 

2.1、单个字面量类型的参数

若 mapper 接口中的方法参数为单个的字面量类型

此时可以使用 ${}#{} 以任意的名称获取参数的值,注意 ${} 需要手动加单引号

    

 

2.2、多个字面量类型的参数

若mapper接口中的方法参数为多个时

此时MyBatis会自动将这些参数放在一个map集合中,以arg0,arg1...为键,以参数为值、以 param1,param2...为键,以参数为值;

因此只需要通过 ${}#{} 访问map集合的键就可以获取相 对应的值,注意 ${} 需要手动加单引号

    

 

2.3、map集合类型的参数

若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在 map中

只需要通过 ${} #{} 访问map集合的键就可以获取相对应的值,注意 ${} 需要手动加单引号

    

 

2.4、实体类类型的参数

若mapper接口中的方法参数为实体类对象时

此时可以使用 ${} #{} ,通过访问实体类对象中的属性名获取属性值,注意 ${} 需要手动加单引号

    insert into t_user values(null,#{username},#{password},#{age},#{gender},#{email})

 

2.5、使用@Param标识参数

可以通过 @Param 注解标识mapper接口中的方法参数

此时,会将这些参数放在map集合中,以@Param注解的value属性值为键,以参数为值;以 param1,param2...为键,以参数为值;

只需要通过 ${} #{} 访问map集合的键就可以获取相对应 的值, 注意 ${} 需要手动加单引号

    

 

 

三、MyBatis的各种查询功能

3.1、查询一个实体类对象

package com.ssm.mybatis.mapper;import com.ssm.mybatis.pojo.User;
import org.apache.ibatis.annotations.Param;import java.util.List;/*** Author:wy* Date:2023/3/18*/public interface SelectMapper {/*** 根据用户id查询用户信息* @param id* @return*/User getUserById(@Param("id") int id);
}

    @Testpublic void testGetUserById() {SqlSession sqlSession = SqlSessionUtil.getSqlSession();SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);User user = mapper.getUserById(1);System.out.println(user);}

 

3.2、查询一个list集合

    /*** 查询所有用户信息* @return*/List getUserList();
    
    @Testpublic void testGetUserList() {SqlSession sqlSession = SqlSessionUtil.getSqlSession();SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);List userList = mapper.getUserList();for (User user : userList) {System.out.println(user);}}

当查询的数据为多条时,不能使用实体类作为返回值,否则会抛出异常TooManyResultsException;

但是若查询的数据只有一条,可以使用实体类或集合作为返回值

 

3.3、查询单个数据

    /*** 查询用户的总记录数* @return*/Integer getCount();
     
    @Testpublic void testGetCount() {SqlSession sqlSession = SqlSessionUtil.getSqlSession();SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);Integer count = mapper.getCount();System.out.println("用户总数=" + count);}

 

3.4、查询一条数据为map集合

    /*** 根据用户id查询用户信息为map集合* @param id* @return*/Map getUserByIdToMap(@Param("id") Integer id);
    
    @Testpublic void testGetUserByIdToMap() {SqlSession sqlSession = SqlSessionUtil.getSqlSession();SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);Map map = mapper.getUserByIdToMap(1);System.out.println(map);//结果:{password=123456, gender=男, id=1, age=21, email=123456@qq.com, username=张三}}

 

3.5、查询多条数据为map集合

方式一

    /*** 查询所有用户信息为map集合* @return* 将表中的数据以map集合的方式查询,一条数据对应一个map;若有多条数据,就会产生多个map集合此时可以将这些map放在一个list集合中获取*/@MapKey("id")List> getAllUserToMap();
    
    @Testpublic void testGetAllUserToMap() {SqlSession sqlSession = SqlSessionUtil.getSqlSession();SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);List> allUserToMap = mapper.getAllUserToMap();for (Map map : allUserToMap) {System.out.println(map);}}

 

方式二

    /*** 查询所有用户信息为map集合* @return* 可以将每条数据转换的map集合放在一个大的map中,* 但是必须要通过@Mapkey注解将查询的某个字段的值作为大的map的键*/@MapKey("id")Map getAllUserToMap();
    
    @Testpublic void testGetAllUserToMap() {SqlSession sqlSession = SqlSessionUtil.getSqlSession();SelectMapper mapper = sqlSession.getMapper(SelectMapper.class);Map map = mapper.getAllUserToMap();System.out.println(map);//{ // 1={password=123456, gender=男, id=1, age=21, email=123456@qq.com, username=张三}, // 2={password=123456, gender=女, id=2, age=19, email=123456@qq.com, username=老六} // }}

相关内容

热门资讯

阿联酋最大银行及另两家中东银行... 观点网讯:5月8日,路透社报道指,阿联酋最大银行第一阿布扎比银行(First Abu Dhabi B...
深圳239亿地王易主,再造万象... 2017年,世茂集团豪掷239.43亿元拿下世茂深港国际中心地块,曾规划建筑高度达700米的深圳第一...
蔚来在安庆成立新能源科技公司 ... 天眼查App显示,近日,安庆蔚来新能源科技有限公司成立,法定代表人为姚蒀,注册资本500万人民币,经...
美国牛肉商期盼峰会重启对华出口 据路透社5月8日报道,美国牛肉生产商正期待特朗普与中国于5月14日至15日的峰会推动对华出口许可恢复...
创业板首家未盈利企业,市值突破... 5月8日,大普微总市值正式突破2000亿元大关。截至午间收盘,大普微涨14.07%,报493.1元/...
招商证券:董事长霍达因工作变动... 招商证券公告,公司董事长霍达因工作变动申请辞去董事长、执行董事等全部职务,辞任自辞呈送达董事会之日生...
原创 中... 【阅读须知】本文所引用的所有信息和数据,均为作者通过查阅官方资料与网络公开数据整理、分析而成,旨在为...
原创 从... 2026年5月5日,中国商务部发布了一项具有划时代意义的专项阻断禁令,这份公告让一向倚仗长臂管辖的美...
布米普特拉北京投资基金管理有限... 美国圣路易斯联邦储备银行总裁穆萨莱姆周三发出明确信号,美联储货币政策面临的潜在风险正在发生关键转向。...
加工的秘密:超精加工设备如何做... 你知道吗? 一根头发丝的直径大约0.07毫米,也就是70微米。 超精加工设备,可切出表面,其尺寸为0...
招商证券董事长霍达因工作变动离... 北京商报讯(记者 刘宇阳 实习生 王思奕)5月8日,招商证券发布关于公司董事长离任暨推举董事代行董事...
华帝股份营收创近3年新低,37... 乐居财经李兰近日,华帝股份(002035.SZ)发布2025年年度报告。 2025年,华帝股份实现营...
大模型融资杀疯了!月之暗面狂揽... 图源:视觉中国 5月7日,据华峰资本官微消息,国内头部大模型公司月之暗面(Kimi)于近日完成新一轮...
扎根长宁二十余载,仲利国际融资... 作为总部扎根上海长宁的优质台资金融企业,仲利国际融资租赁有限公司深耕融资租赁行业二十余载,始终坚守金...
估值210亿!李彦宏又将收获一... 来源:直通IPO,文/王非 国产GPU上市潮仍然汹涌,继两家登陆A股、两家登陆H股后,这家公司正推进...
基金“盲盒”拆了 公募基金正在迎来一场让投资者“看得懂”的变革。 近日,华夏、易方达、南方、招商等12家头部及特色基金...
原创 2... 前言 十年间,中国企业在印尼镍产业链累计砸下超过140亿美元,电厂、公路、码头和全套生产线,硬生生...
原创 欧... 俄罗斯卫星通讯社5月6日报道,欧盟宣布禁止欧洲银行为含有来自不可靠供应商的关键部件的可再生能源项目提...
原创 余... 2026年5月2日,在中国理财市场扎根十三年的余额宝,终于触碰到了一个让所有人错愕的数字——7日年化...
银华基金增聘谭普景共同管理银华... 来源:新浪基金∞工作室 5月8日,银华基金管理股份有限公司发布公告称,为银华中证机器人交易型开放式指...