zoukankan      html  css  js  c++  java
  • 在 mapper 中如何传递多个参数?

    1、第一种

    DAO 层的函数 

    public UserselectUser(String name,String area);

    对应的 xml,#{0}代表接收的是 dao 层中的第一个参数,#{1}代表 dao 层中第二 

    参数更多参数一致往后加即可

    <select id="selectUser"resultMap="BaseResultMap">

    select * fromuser_user_t

    whereuser_name = #{0}

    anduser_area=#{1}

    </select>

    2、第二种使用 @param 注解:

    public interface usermapper {

    user selectuser(@param(“username”) string

    username,@param(“hashedpassword”) string hashedpassword);

    }

    然后,就可以在 xml 像下面这样使用(推荐封装为一个 map,作为单个参数传递给 

    mapper):

    <select id=”selectuser” resulttype=”user”>

    select id, username, hashedpassword

    from some_table

    where username = #{username}

    and hashedpassword = #{hashedpassword}

    </select>

    3、第三种多个参数封装成 maptry {

    //映射文件的命名空间.SQL 片段的 ID,就可以调用对应的映射文件中的 

    SQL

    //由于我们的参数超过了两个而方法中只有一个 Object 参数收集因此 

    我们使用 Map 集合来装载我们的参数 

    Map < String, Object > map = new HashMap();

    map.put("start", start);

    map.put("end", end);

    return sqlSession.selectList("StudentID.pagination", map);

    } catch (Exception e) {

    e.printStackTrace();

    sqlSession.rollback();

    throw e;

    } finally {

    MybatisUtil.closeSqlSession();

    }

  • 相关阅读:
    vue项目index.html , main.js的关系
    vue项目是如何加载入口文件main.js的
    解决Mysql密码修改后不能登录的问题
    解决IDEA右侧maven不显示方法
    (转)sql语句定义和执行顺序
    关于我
    css中好用的clamp()函数
    vue中子组件使用$emit传值的种种情况
    我的大学 -詹书庭
    自定义组件使用v-model
  • 原文地址:https://www.cnblogs.com/programb/p/12996191.html
Copyright © 2011-2022 走看看