配置文件xml和properties

XML 复制代码
driver=com.microsoft.sqlserver.jdbc.SQLServerDriver

url =jdbc:sqlserver://localhost:1433;DatabaseName=chenyuan;encrypt=true;trustServerCertificate=true
user = sa
password = 123456

要让你的 mybatis-config.xml 配置文件成功读取到 mybatis.properties 文件中的数据库连接信息,你只需要在 <configuration> 标签内部的最上方,添加一个 <properties> 标签来引入该属性文件。

修改后的 mybatis-config.xml 代码如下:

复制代码
<?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="mybatis.properties"/>

    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    </environments>
    
    <mappers>
        <mapper resource="org/mybatis/example/BlogMapper.xml"/>
    </mappers>
</configuration>

💡 两个需要注意的细节(避坑指南):

先把 mybatis-config.xml 里的路径改成 com/counter/dao/Usermapper.xml 吧,距离成功运行就差这一步了!

复制代码
<build>
    <resources>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.xml</include>
            </includes>
            <filtering>false</filtering>
        </resource>
    </resources>
</build>
  1. 标签的顺序不能乱 :MyBatis 对 XML 内部标签的顺序有严格要求。<properties> 标签必须 放在 <configuration> 的第一位(在 <environments><mappers> 的上方),否则项目启动时会报 XML 校验错误。

  2. 文件的存放路径 :代码中的 resource="mybatis.properties" 表示从类路径(ClassPath)根目录下寻找该文件。在标准的 Maven 或 SSM 项目中,你需要把 mybatis.propertiesmybatis-config.xml 都放在 src/main/resources 目录下。

    是的,你观察得非常敏锐!这里确实还没有绑定。 如果不在这里修改路径,MyBatis 启动时就会去报错找不到 org/mybatis/example/BlogMapper.xml,从而无法加载你的 SQL 语句。

    看一眼你左侧的项目结构,你的 Usermapper.xml 是直接放在 com/counter/dao 这个包路径下的。因此,你必须把 mybatis-config.xml 第 20 行的 <mapper> 标签修改为你项目的真实路径。

    请将第 19-21 行的 <mappers> 标签区域修改为以下内容:

    XML

    复制代码
        <mappers>
            <mapper resource="com/counter/dao/Usermapper.xml"/>
        </mappers>

    💡 顺便提醒一个极易踩坑的"资源导出问题":

    在 Maven 项目中,如果你把 XML 映射文件(如 Usermapper.xml)放在 src/main/java 的主代码包下,而不是放在 src/main/resources 资源目录下,Maven 在编译时默认会忽略掉 java 包底下的 XML 文件。

    这会导致程序运行时报经典的 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 错误。

    解决办法(二选一):

  3. 推荐做法 :在右侧 resources 目录下新建一个一模一样的空文件夹目录 com/counter/dao,然后把 Usermapper.xml 挪过去。

  4. 快捷做法 :如果不挪动文件,就必须在你项目的 pom.xml 中加入以下 资源过滤配置,强迫 Maven 去编译 java 文件夹下的 XML 文件:

相关推荐
竹林81811 分钟前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花28 分钟前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12271 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪2 小时前
Vue3-生命周期
前端
莪_幻尘2 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程
lichenyang4532 小时前
从 has.echo 到异步 API 注册表:一次 ASCF API 回调不触发的排查复盘
前端
林瞅瞅3 小时前
Nuxt3 项目部署 Nginx 防盗链后特定 JS 文件 403 问题修复方案
前端
kyriewen3 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
一颗奇趣蛋3 小时前
Web 视频开发完全指南:从入门到精通
前端
非洲农业不发达4 小时前
windows终端体验大升级,让你拥有macos级别的美化
前端·后端