开发者

Mybatis注解sql时出现的一个错误及解决

开发者 https://www.devze.com 2023-02-08 10:49 出处:网络 作者: 阿皮匹
目录一.  错误二.  文件结构 BookMapper.JavaBookMapperSQL .javaMyBATis的配置文件三.  分析总结一.  错误
目录
  • 一.  错误
  • 二.  文件结构 
    • BookMapper.Java
    • BookMapperSQL .java
    • MyBATis的配置文件
  • 三.  分析
    • 总结

      一.  错误

      在做Mybatis用注解方式来注入sql的练习时,报了这样子的错误。

      遇到错误很正常,然后我又从学了一遍今天刚刚学的内容,温故而知新嘛。

      错误问题如下:

      Mybatis注解sql时出现的一个错误及解决

      Mybatis注解sql时出现的一个错误及解决

      二.  文件结构 

      BookMapper.java

      puONAuWZZblic interface BookMapper {
          @SelectProvider(type = BookMapperSQL.class,method = "bookSelectById")
          Book bookSelectById(int id);
       
      }

      B编程客栈ookMapperSQL .java

      public class BookMapperSQL {
          public String bookSelectById(final int id){
              开发者_JS教程return new SQL().
                      SELECT("*")
                      .FROM("t_user")
                      .WHERE("id=#{id}").toString();
       
          }
      }

      然后我把BookMapper.XML的内容都删完了,没有把文件删掉,目录如下:

      Mybatis注解sql时出现的一个错误及解决

      Mybatis的配置文件

      这个映射用包用类其实都没有影响,因为我们做的是注解配置

      <?xml version="1.0" encoding="UTF-8" ?>
      <!DOCTYPE configuration
              PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
              "http://mybatis.org/dtd/mybatis-3-config.dtd">
      <configuration>
          <properties resource="Dd.properties"/>
          <settings>
              <setting name="logImpl" value="STDOUT_LOGGING"/>
          </settings>
          <typeAliases>
              <package name="org.example.po"/>
          </typeAliases>android
          <environments default="development">
              <environment id="development">
                  <transactionManager type="JDBC"/>
                  <dataSource type="POOLED">
                      <property name="driver" value="${db.driver}"/>
                      <property name="url" value=编程客栈"${db.url}"/>
                      <property name="username" value="${db.username}"/>
                      <property name="password" value="${db.password}"/>
                  </dataSource>
              </environment>
          </environments>
          <mappers>
      <!--        <mapper class="org.example.mapper.BookMapper"/>-->
              <package name="org.example.mapper"/>
          </mappers>
      </configuration>

      三.  分析

      从上面的文件看,我的问题很大部分原因应该在这个mapper的包里面。然后就是看参数有没有个数对齐,但是也不会导致这样的错误说是错误解析SQL Mapper配置,所以这个问题我一开始纠结于那个BookMapperSQL 编程.java的内容是不是写错了,研究了一个多小时,直接重学了一遍,哭了。

      后来我在想,会不会是因为我拿的是我之前做的作业修改的而出现的问题。然后我就看了我之前的文件目录

      Mybatis注解sql时出现的一个错误及解决

      我突然想起之前做这个动态代理方式实现的方式时,pom.xml文件做了配置,指定了mapper包中。

      Mybatis注解sql时出现的一个错误及解决

      难道就是因为指定了位置,文件加载所以出问题了吗?所以我就把这段代码注释掉

      然后它就运行成功了。 

      Mybatis注解sql时出现的一个错误及解决

      当热,我们在使用注解方式注入sql时,mapper包中没必要再加这个文件了,只能说是自己愚钝了,上网查都没有人像我一样这么乌龙了。

      总结

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

      0

      精彩评论

      暂无评论...
      验证码 换一张
      取 消

      关注公众号