• MyBatis指定查询类容、多表查询


    上一次讲到,使用MyBatis查询所有的数据,没有用到接口里的方法。

    这一次我们补充一下,使用接口方法,传入参数查询数据。

    首先根据上一次的代码进行增加:

    (22条消息) 最详细的MyBatis构建,极其细腻教学。建议入门操作_小肖在路上的博客-CSDN博客

    修改接口:

    1. public interface userMapper {
    2. User selectUserId(int id);
    3. }

     就纯粹的加入一个带参数的查询方法就可以了。

    然后我们更改一下UserMapper.xml文件:

    1. "1.0" encoding="UTF-8" ?>
    2. mapper
    3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    5. <mapper namespace="com.quxiao.mybatis.mapper.userMapper">
    6. <select id="selectUserId" resultType="com.quxiao.mybatis.pojo.User" parameterType="int">
    7. select * from bus.user where id=#{id}
    8. select>
    9. mapper>

    这里的查询条件的参数在xml中使用:#{id}

    id只是一个标识名字,可以更改,尽量见名知意。

    然后测试内也改一下:

    1. @Test
    2. public void testSelectAll() {
    3. SqlSession session = sqlSessionFactory.openSession();
    4. try {
    5. // List userList = session.selectList("selectAll");
    6. // userList.stream()
    7. // .forEach(x -> System.out.println(x));
    8. userMapper userMapper = session.getMapper(userMapper.class);
    9. User user = userMapper.selectUserId(1);
    10. System.out.println(user);
    11. } finally {
    12. session.close();
    13. }
    14. }

    将原来查询代码注销掉,本次的查询返回是一个实体类,不需要用list存储。

    然后就是多表查询:

    这里我们要创建另一张表的实体类:

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

     加入MyBatis查询语句:

    然后就可以啦,运行和上一个一模一样。更改接收类型就好了。。。

    看到这里,大家一定回想,如果我想把两张表都接受到咋办呢??

     所以我们就在两个实体类另一个实体类中放入User:

    这样我们就可以存入啦~~

    然后就是一个在写MyBatis的sql时有一个知识点:

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

    然后就直接输出就好了:

  • 相关阅读:
    pytorch中gather函数的理解
    Linux新手教程||Linux vi/vim
    gorm存储json
    推荐系统(RS)
    交换机的工作原理
    个人练习-PAT甲级-1129 Recommendation System
    pandas使用列表(list)数据创建dataframe、pandas使用嵌套列表(nested list)数据创建dataframe
    贪心算法在找零问题中的应用
    6.10版本内核体验
    windows修改默认端口3389
  • 原文地址:https://blog.csdn.net/qx020814/article/details/127414014