Mybatis注解sql时出现的一个错误及解决
一. 错误
在做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包中没必要再加这个文件了,只能说是自己愚钝了,上网查都没有人像我一样这么乌龙了。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
spring如何集成cxf实现webservice接口功能详解
这篇文章主要给大家介绍了关于spring如何集成cxf实现webservice接口功能的相关资料,文中通过示例代码介绍的非常详细,对大家 的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧2018-07-07SpringBoot快速整合SpringSecurity的详细步骤(新手都会!)
日 Spring Security 是针对Spring项目的安全框架,也是Spring Boot底层安全模块默认的技术选型,他可以实现强大的Web安全控制,下面这篇文章主要给大家介绍了关于SpringBoot快速整合SpringSecurity的详细步骤,需要的朋友可以参考下2023-03-03
最新评论