上一次讲到,使用MyBatis查询所有的数据,没有用到接口里的方法。
这一次我们补充一下,使用接口方法,传入参数查询数据。
首先根据上一次的代码进行增加:
(22条消息) 最详细的MyBatis构建,极其细腻教学。建议入门操作_小肖在路上的博客-CSDN博客
修改接口:
- public interface userMapper {
- User selectUserId(int id);
- }
就纯粹的加入一个带参数的查询方法就可以了。
然后我们更改一下UserMapper.xml文件:
- "1.0" encoding="UTF-8" ?>
- mapper
- PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
-
- <mapper namespace="com.quxiao.mybatis.mapper.userMapper">
-
- <select id="selectUserId" resultType="com.quxiao.mybatis.pojo.User" parameterType="int">
- select * from bus.user where id=#{id}
- select>
- mapper>
这里的查询条件的参数在xml中使用:#{id}
id只是一个标识名字,可以更改,尽量见名知意。
然后测试内也改一下:
- @Test
- public void testSelectAll() {
- SqlSession session = sqlSessionFactory.openSession();
- try {
- // List
userList = session.selectList("selectAll"); - // userList.stream()
- // .forEach(x -> System.out.println(x));
- userMapper userMapper = session.getMapper(userMapper.class);
- User user = userMapper.selectUserId(1);
- System.out.println(user);
- } finally {
- session.close();
- }
- }
将原来查询代码注销掉,本次的查询返回是一个实体类,不需要用list存储。
然后就是多表查询:
这里我们要创建另一张表的实体类:

然后添加多表查询的接口方法:

加入MyBatis查询语句:

然后就可以啦,运行和上一个一模一样。更改接收类型就好了。。。
看到这里,大家一定回想,如果我想把两张表都接受到咋办呢??
所以我们就在两个实体类另一个实体类中放入User:

这样我们就可以存入啦~~
然后就是一个在写MyBatis的sql时有一个知识点:

这里可以直接使用user.name存入,因为MyBatis时反射机制,就算user的name是私有的,也可以存入噢。
然后就直接输出就好了:
