欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Mybatis详解在注解sql时报错的解决方法

时间:2022-11-15 09:46:30|栏目:JAVA代码|点击:

错误:

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

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

错误问题如下:

文件结构

BookMapper.java

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

BookMapperSQL .java

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

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

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>
    <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的内容是不是写错了,研究了一个多小时,直接重学了一遍,哭了。

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

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

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

,然后它就运行成功了。 

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

上一篇:使用maven-assembly-plugin如何打包多模块项目

栏    目:JAVA代码

下一篇:mybatis的大于小于号转义符号一览

本文标题:Mybatis详解在注解sql时报错的解决方法

本文地址:http://www.codeinn.net/misctech/219017.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有