mybatis执行错误但sql执行正常问题

 更新时间:2024年01月27日 14:49:10   作者:Aoeding  
这篇文章主要介绍了mybatis执行错误但sql执行正常问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mybatis执行错误但sql执行正常

大概率是存在特殊字符使mybatis解析异常

1.在mapper.java中的方法上添加@SqlParser(filter=true)注解


在这里插入图片描述

2.如果sql中有注释,删掉注释


在这里插入图片描述

mybatis执行sql语句的两种方式

SqlSession.mapper和SqlSession.selectXxx对比

MyBatis中有两种SQL语句的执行方式,如下:

  • 通过SqlSession发送SQL语句
  • 例如:sqlSession.slectone()的形式。
  • 通过SqlSession获取Mapper接口,通过Mapper接口发送SQL语句
  • 例如:sqlSession.getMapper()的形式。

封装工具类

封装一个类SqlSession工具类,用于生产SqlSession对象,下面的例子为了节省代码将会使用我们封装的SqlSessionUtil工具类。

public class SqlSessionUtil {

    public static SqlSession getSqlSession(){
        SqlSession sqlSession = null;
        try {
            // 获取核心配置文件的输入流
            InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
            // 获取SqlSessionFactoryBuilder
            SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
            // 获取SqlSessionFactory
            SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
            // 获取SqlSession对象
            sqlSession = sqlSessionFactory.openSession(true);

        } catch (IOException e) {
            throw new RuntimeException(e);
        }
        return sqlSession;
    }
}

创建Mapper映射文件

<mapper namespace="com.jingchao.mybatis.mapper.UserMapper">
    <select id="selectUserById" resultType="User">
        select * from t_user where id = #{id}
    </select>
</mapper>

创建Mapper接口

public interface UserMapper{
    User selectUserById(@Param("id") Integer id);
}

SqlSession发送SQL语句

selectOne方法表示查询一条语句,通过String类型的命名空间加上Sql语句标签的id来精准定位一条SQL语句。

从而实现SQL语句的发送。

SqlSession sqlSession = SqlSessionUtil.getSqlSession();
User user = sqlSession.selectOne("com.jingchao.mybatis.mapper.UserMapper.selectUserById", 1);

Mapper接口发送SQL语句

通过Mapper接口发送SQL是通过动态代理的方式(sqlSession.getMapper(UserMapper.class))获取mapper接口对象,通过调用mapper中的方法,实现发送SQL语句,这样完全避免了通过实现Mapper接口的方式来直接执行对应的SQL语句。

总结:通过Mapper接口发送SQL语句的方式就是MyBatis以代理的方式帮我们创建了接口的实现类

SqlSession sqlSession = SqlSessionUtil.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.selectUserById(1);

两种方式的对比

通过SqlSession发送SQL语句

不需要定义mapper(dao)接口,可以直接通过“ 命名空间 + id ”的方式发送SQL语句

通过SqlSession获取Mapper接口,再通过Mapper接口发送SQL语句

需要定义mapper接口,并在接口中定义抽象方法,通过获取mapper接口对象,再调用方法的形式发送SQL语句。

说明:建议使用Mapper接口发送SQL语句的方式,理由如下:

  • 使用Mapper接口编程可以消除SqlSession带来的功能性代码,提高代码可读性
  • 使用Mapper接口,是完全体现面向对象的语言,更加体现业务的逻辑
  • 使用Mapper接口的方式,可以提前进行代码的错误提示和检验,而直接使用SqlSession的方式,只有在代码运行时才会知道是否产生错误

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java struts2捕获404错误的方法汇总

    Java struts2捕获404错误的方法汇总

    这篇文章主要为大家详细汇总了Java struts2捕获404错误的常用方法,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • 10个Java文件操作必备技巧分享

    10个Java文件操作必备技巧分享

    在我们日常的开发中,文件操作是一个非常重要的主题。文件读写、文件复制、任意位置读写、缓存等技巧都是我们必须要掌握的。本文为大家整理了10个实用的文件操作技巧,希望对大家有所帮助
    2023-04-04
  • spring异步service中处理线程数限制详解

    spring异步service中处理线程数限制详解

    这篇文章主要给大家介绍了关于spring异步service中处理线程数限制的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用spring具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • Hadoop2.8.1完全分布式环境搭建过程

    Hadoop2.8.1完全分布式环境搭建过程

    本文搭建了一个由三节点(master、slave1、slave2)构成的Hadoop完全分布式集群(区别单节点伪分布式集群),并通过Hadoop分布式计算的一个示例测试集群的正确性。对hadoop分布式环境搭建过程感兴趣的朋友跟随小编一起看看吧
    2019-06-06
  • 利用JWT如何实现对API的授权访问详解

    利用JWT如何实现对API的授权访问详解

    这篇文章主要给大家介绍了关于利用JWT如何实现对API的授权访问的相关资料,需要的朋友可以参考下
    2018-09-09
  • Response如何实现重定向

    Response如何实现重定向

    这篇文章主要介绍了Response如何实现重定向方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Java的动态代理和静态代理详解

    Java的动态代理和静态代理详解

    这篇文章主要为大家详细介绍了Python实现学生成绩管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • mybatis注解开发使用foreach方式

    mybatis注解开发使用foreach方式

    这篇文章主要介绍了mybatis注解开发使用foreach方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Java 异步实现的几种方式小结

    Java 异步实现的几种方式小结

    这篇文章主要介绍了Java 异步实现的几种方式小结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • 通过Feign进行调用@FeignClient 找不到的解决方案

    通过Feign进行调用@FeignClient 找不到的解决方案

    这篇文章主要介绍了通过Feign进行调用@FeignClient 找不到的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03

最新评论