当前位置: 首页 > 面试题库 >

在 mapper 中如何传递多个参数?

彭开畅
2023-03-14
本文向大家介绍在 mapper 中如何传递多个参数?相关面试题,主要包含被问及在 mapper 中如何传递多个参数?时的应答技巧和注意事项,需要的朋友参考一下

1、第一种:

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、第三种:多个参数封装成 map

try {
    //映射文件的命名空间.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();
}
 类似资料:
  • 问题内容: 我试图弄清楚如何在URL中传递多个参数。我想将纬度和经度从我的android类传递给Java servlet。我怎样才能做到这一点? 在这种情况下,输出(写入文件)为。这是可行的,但我想在两个单独的参数中传递纬度和经度,以便减少在服务器端的工作。如果不可能,我如何至少在&之间添加一个空格,以便可以使用class获取经度和纬度。我试过以下行,但无济于事。 我的servlet代码如下: 我

  • 但是,当我试图将此代码更改为以下代码时,我得到了一个错误-错误:Main method,在类MyClass中找不到,请将Main method,定义为:public static void Main(string[]args)。我需要接收owner和consumerName作为我的程序的参数/输入。 ,这是怎么做到的?

  • 问题内容: 假设我有这个功能: 我想这样称呼它: 当然,不能用这种方法来完成,因为Postgres试图用该名称和三个不存在的参数来查找函数。 我试图用引号引起来,但在这种情况下,参数解释错误: data1’,’data2’,’data3 ,就像一个字符串一样。 有没有一种方法可以在参数中放置多个值,以便IN子句可以识别它? 问题答案: 您的函数将不会被创建。之后是句法废话。 无论哪种方式,带有 参

  • 问题内容: 我想同时向我的模板渲染2样东西: 但是Playframework说,这是错误的。那么如何同时渲染2个值呢?我应该将它们保存到列表中吗?但是然后我必须再次将其解压缩到模板中。 请帮忙!感谢任何帮助! 问题答案: 2.0中的播放模板只是Scala函数,因此您需要在模板的开头(从第1行开始)声明params: 查看模板文档以获取详细信息 地图 另一方面,如果您需要传递大量相同类型的变量,那么

  • 任何帮助都将不胜感激。谢谢!

  • 问题内容: 如何在Go中将多个外部命令通过管道传递?我已经试过了这段代码,但是看到一条错误消息。 问题答案: StdoutPipe返回一条管道,该管道将在命令启动时连接到命令的标准输出。在Wait看到命令退出后,管道将自动关闭。 (来自http://golang.org/pkg/os/exec/#Cmd.StdinPipe) 您确实关闭了事实。 我做了一个工作示例(只是一个演示,添加了错误捕获功能