在spring boot项目中创建mapper接口,编写xml文件sql语句,执行出现错误

报错

这个错是maven加载机制造成的问题 ,maven加载的时候,把Java文件夹里面.Java类型文件进行编译,如果其他类型文件,就不会加载

解决方式

1.复制xml到target目录中

2.把xml文件放到resources目录中

3.推荐使用:通过配置实现

( 1 ) pom.xml里面添加配置

在pom文件中配置如下节点

<!-- 项目打包时会将Java目录中的*.xml文件也进行打包 -->
    <build>
        <resources>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>
    </build>

重新打包项目会发现target目录下出现了xml文件夹

( 2 ) application.properties里添加配置

#配置mapper xml文件的路径
mybatis-puls.mapper-locations=classpath:com/guli/edu/mapper/xml/*.xml

如果还是找不到(本人就是),就直接在mapper文件上用注释写语句
例如

在使用MyBatis访问数据库时,需要创建Mapper接口和对应的Mapper XML文件来定义SQL语句以及对应的结果集映射。下面是具体的步骤: 1. 创建Mapper接口项目的src/main/java目录下创建一个Mapper接口,例如UserMapper.java。Mapper接口需要定义访问数据库的方法,比如查询、插入、修改和删除等,方法的名称和参数需要和Mapper XML文件定义的SQL语句对应。例如: ``` public interface UserMapper { List<User> selectAllUsers(); void insertUser(User user); void updateUser(User user); void deleteUser(int id); } ``` 2. 创建Mapper XML文件项目的src/main/resources目录下创建一个Mapper XML文件,例如UserMapper.xmlMapper XML文件需要定义访问数据库的SQL语句以及对应的结果集映射,例如: ``` <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.demo.mapper.UserMapper"> <select id="selectAllUsers" resultType="User"> SELECT * FROM users </select> <insert id="insertUser" parameterType="User"> INSERT INTO users (name, age) VALUES (#{name}, #{age}) </insert> <update id="updateUser" parameterType="User"> UPDATE users SET name=#{name}, age=#{age} WHERE id=#{id} </update> <delete id="deleteUser" parameterType="int"> DELETE FROM users WHERE id=#{id} </delete> </mapper> ``` 在Mapper XML文件,需要指定mapper的namespace,以及定义各种SQL语句。其,id属性指定了SQL语句的名称,parameterType属性指定了方法参数的类型,resultType属性指定了返回结果的类型。 完成以上步骤后,就可以在Spring Boot应用程序使用Mybatis访问数据库了。在需要使用Mapper接口的地方,可以通过@Autowired注解自动注入Mapper接口,然后调用其定义的方法,即可完成对数据库的访问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值