配置文件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 文件:

相关推荐
jnene1 小时前
html 时间、价格筛选样式处理
前端·css·html
slongzhang_2 小时前
jquery 修复怪异模式html未声明“<!DOCTYPE html>”
前端·html·jquery
云水一下2 小时前
Vue.js从零到精通系列(三):组件化基础——Props、Emits、插槽与生命周期
前端·javascript·vue.js
SEO_juper3 小时前
新独立站冷启动收录全攻略:配置、推送、抓取配额优化完整手册
前端·谷歌·seo·跨境电商·外贸·geo·独立站
TinssonTai3 小时前
这个 VS Code 插件让我的 AI Coding 又快又稳 - 旧瓶装新酒
前端·人工智能·程序员
体验家3 小时前
体验家 XMPlus 网页端问卷 SDK 技术解析:用几行 JavaScript 实现精准场景触发与防打扰机制
开发语言·前端·javascript
Maimai108083 小时前
Web3 前端交易系统如何落地:从下单 UI 到 Operation 编码、签名与实时状态更新
前端·react.js·ui·架构·前端框架·web3
kidding7233 小时前
高效备忘清单工具类小程序
前端·计算机网络·微信小程序·小程序
IMPYLH4 小时前
HTML 的 <abbr> 元素
前端·算法·html