叫我小周同学 2022-04-10 14:46 采纳率: 100%
浏览 39
已结题

mybatis中使用注解编写sql为什么不能用重载

碰见一个令人无语的事情,mybatis下使用注解编写sql,方法名相同,参数不同运行的时候居然会报错?

就像下面这样,一个带参数一个不带参数


 @Select("select * from tb_user")
    List<User> select();

    @Select("select * from tb_user where username=#{username} and password=#{password}")
    User select(String username,String password);

再看一下测试代码


```java
@SuppressWarnings({"all"})
public class usermapper {
    public static void main(String[] args) throws IOException {

        SqlSession sqlSession = SqlSessionFactorUtil.getSqlSessionFactory().openSession();
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);



        List<User> select = mapper.select();

        System.out.println(select);
        sqlSession.commit();
        sqlSession.close();
    }
}
**
然后就报错了,随便取了一点上来**
**看见报错信息我真是一脸懵逼啊,百思不得其解,最后跟以前写的代码做了对比,把同名方法改了个名字就能运行成功了**


```java
 @Select("select * from tb_user")
    List<User> selectALL();


    @Select("select * from tb_user where username=#{username} and password=#{password}")
    User select(String username,String password);

  • 写回答

1条回答 默认 最新

  • a1767028198 2022-04-10 15:29
    关注

    和注解无关,原生mybatis采用类名+方法名为唯一标记生成stamentid,添加到全局配置中,发现stamentid重复直接启动报错,mybatis plus改写了这部分逻辑,可以正常启动,这也告诉我们,mybatis就不推荐你重载,请勿重载

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月28日
  • 已采纳回答 4月20日
  • 创建了问题 4月10日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分