MyBatis获取参数值的两种方式
admin
2024-03-06 04:45:10
0

MyBatis获取参数值的两种方式: #{}(占位符赋值)和  ${}(字符串拼接)

1. 若mapper接口方法的参数为单个的字面量类型,此时可以通过#{}和${}以任意的内容获取参数值,但是要注意${}的单引号问题

UserMapper.java接口:

     /*** 根据用户名查找用户信息* @param username* @return*/User getUserByUsername(String username);

UserMapper.xml映射文件:

    

测试代码:

    @Testpublic void testGetUserByUsername(){// SqlSessionUtil类是提前创建好的一个工具类,可参考前几篇文章查看详细代码SqlSession sqlSession = SqlSessionUtil.getSqlSession();UserMapper userMapper = sqlSession.getMapper(UserMapper.class);User user = userMapper.getUserByUsername("王五");System.out.println(user);sqlSession.close();}

2. 若mapper接口方法的参数为多个的字面量类型,此时会将参数放在map集合中,以两种方式存储数据:

         (1)以arg0,arg1,...为键,以参数为值

         (2)以param1,param2,...为键,以参数为值

UserMapper.java接口:

    /*** 验证登录* @param username* @param password* @return*/User checkLogin(String username, String password);

UserMapper.xml映射文件:

    

测试代码:

    @Testpublic void testCheckLogin(){SqlSession sqlSession = SqlSessionUtil.getSqlSession();UserMapper userMapper = sqlSession.getMapper(UserMapper.class);User user = userMapper.checkLogin("admin", "444");System.out.println(user);System.out.println(user.getUsername());sqlSession.close();}

3. 若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中,此时只需要通过#{}或${}以访问Map集合的键就可以获得对应的值,要注意${}的单引号。

UserMapper.java接口:

    /*** 验证登录 — 以自定义的Map集合作为参数* @param map* @return*/User checkLoginByMap(Map map);

UserMapper.xml映射文件:

    

测试代码:

    @Testpublic void testCheckLoginByMap(){SqlSession sqlSession = SqlSessionUtil.getSqlSession();UserMapper userMapper = sqlSession.getMapper(UserMapper.class);Map map = new HashMap<>();map.put("username", "admin");map.put("password", "444");User user = userMapper.checkLoginByMap(map);System.out.println(user);sqlSession.close();}

4. 若mapper接口方法的参数是实体类型的参数,只需要通过#{}和${}访问实体类中的属性名,就可以获得对应的属性值,要注意${}的单引号问题

UserMapper.java接口:

    /*** 添加用户信息* @param user*/void insertUser(User user);

UserMapper.xml映射文件:

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

测试代码:

    @Testpublic void testInsertUser(){SqlSession sqlSession = SqlSessionUtil.getSqlSession();UserMapper userMapper = sqlSession.getMapper(UserMapper.class);User user = new User(null, "root", "123456", 33, "女", "456@qq.com");userMapper.insertUser(user);sqlSession.close();}

5. 可以在mapper接口方法的参数上设置@Param注解,MyBatis会将这些参数放在map中,以两种方式进行存储:

        (1)以@Param注解的属性值为键,以参数为值

        (2)以param1,param2,...为键,以参数为值

         此时可以通过#{}和${}以任意的内容获取参数值,要注意${}的单引号问题

UserMapper.java接口:

    /*** 验证登录 - 使用@Param注解* @param username* @param password* @return*/User checkLoginByParam(@Param("username") String username, @Param("password") String password);

UserMapper.xml映射文件:

    

测试代码:

    @Testpublic void testCheckLoginByParam(){SqlSession sqlSession = SqlSessionUtil.getSqlSession();UserMapper userMapper = sqlSession.getMapper(UserMapper.class);User user = userMapper.checkLoginByParam("admin", "444");System.out.println(user);sqlSession.close();}

相关内容

热门资讯

吹风机养生:真能顶得上老中医吗... 近年来,社交平台上流行起了“吹风机养生”的说法,许多博主宣称用吹风机对着特定的穴位吹热风,可以温阳驱...
深夜王炸,GPT-5.5发布 财联社 美东时间周四,OpenAI公布了其最新的人工智能模型——GPT-5.5。该公司表示,该模型在...
台湾同胞参加海军成立77周年纪... 4月23日,台湾同胞登上海军舰艇参观并与海军军官合影留念。新华社记者 李杰 摄 新华社青岛4月23日...
特朗普:这世界疯了 美国司法部当地时间4月23日证实,参与强行控制并转移委内瑞拉总统马杜罗的美国陆军特种部队军士长甘农·...
从冲击千亿市值到被申请破产重整... 图/ic 八年亏损超84亿元!“中国影视第一股”华谊兄弟被申请重整。 4月23日晚,华谊兄弟传媒股份...
“保安与停车女子和好接吻”,A... 撰稿/苏士仪(媒体人) 编辑/王言虎 校对/王心 ▲女司机与保安发生肢体冲突一事,持续引发关注。图...
美伊冲突前景不明 国际油价再度... 当地时间4月24日,由于美国与伊朗冲突前景仍不明朗,市场避险情绪升温,国际油价再度上涨。布伦特原油上...
美国发生群体性枪击事件,8名1... 新华社消息,美国路易斯安那州什里夫波特市19日发生一起群体性枪击事件,造成8名儿童死亡,枪手被警方击...
274亿美金砸向核武器,威慑还... 文︱陆弃 能源部长克里斯·赖特在2026年4月16号的一场公开场合称,美国正在推进的核武器现代化计划...