Mybatis-Plus中实现使用xml文件来写复杂sql

一、前言

我们一般的sql语句使用Mabatis-Plus可以满足,但是到了连表和复杂的需求时,还是需要像Mybatis那样在xml中来书写sql语句,但是一个项目中只能有一个,所以我们在使用Mybatis-Plus时,就不需要在导入Mybatis的依赖,Mybatis-Plus也可以直接在xml文件中写,不过是yml文件中的配置不一样!

二、具体配置

  • Mybatis-Plus所需依赖
	<!-- mybatis-plus -->
      <dependency>
          <groupId>com.baomidou</groupId>
          <artifactId>mybatis-plus-boot-starter</artifactId>
          <version>3.1.0</version>
      </dependency>
  • yml文件配置
#原来mybatis的配置,我们删除就行
mybatis:
 mapper-locations: classpath:mapper/*.xml
 type-aliases-package: com.wang.test.demo.entity

#直接用这个,在xml文件中也可以书写sql
mybatis-plus:
  mapper-locations: classpath:mapper/*.xml
  type-aliases-package: com.wang.test.demo.entity
  • 额外的yml文件配置
#执行的sql会在控制台打印
logging:
 level:
  com.wang.test.demo: DEBUG #写自己的包路径就行

三、总结

其实就和Mybatis的匹配一样,Mybatis换成了Mybatis-Plus,自己在使用时,遇到的问题,在这里分享给大家!

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Mybatis-Plus 对于 SQL Server 的 XML 类型的处理需要特殊的配置。具体步骤如下: 1. 在 pom.xml 文件添加对 SQL Server 驱动的依赖: ```xml <dependency> <groupId>com.microsoft.sqlserver</groupId> <artifactId>mssql-jdbc</artifactId> <version>${sqlserver.version}</version> </dependency> ``` 2. 在 mybatis-plus 的配置文件添加对 SQL Server 数据库方言的配置,如下所示: ```xml <bean id="mybatisPlusConfig" class="com.baomidou.mybatisplus.core.MybatisConfiguration"> <property name="mapUnderscoreToCamelCase" value="true"/> <property name="databaseIdProvider" ref="databaseIdProvider"/> <property name="dbConfig" ref="dbConfig"/> <property name="sqlParserConfig" ref="sqlParserConfig"/> <property name="typeHandlersPackage" value="com.baomidou.mybatisplus.extension.handlers"/> <property name="dialect" value="sqlserver"/> </bean> ``` 3. 定义一个 TypeHandler,用于将 XML 类型的数据转换为字符串类型的数据,如下所示: ```java import java.sql.CallableStatement; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.SQLXML; import org.apache.ibatis.type.BaseTypeHandler; import org.apache.ibatis.type.JdbcType; public class SqlServerXmlTypeHandler extends BaseTypeHandler<String> { @Override public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException { SQLXML xml = ps.getConnection().createSQLXML(); xml.setString(parameter); ps.setSQLXML(i, xml); } @Override public String getNullableResult(ResultSet rs, String columnName) throws SQLException { SQLXML xml = rs.getSQLXML(columnName); if (xml == null) { return null; } return xml.getString(); } @Override public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException { SQLXML xml = rs.getSQLXML(columnIndex); if (xml == null) { return null; } return xml.getString(); } @Override public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { SQLXML xml = cs.getSQLXML(columnIndex); if (xml == null) { return null; } return xml.getString(); } } ``` 4. 在 mybatis-plus 的配置文件注册该 TypeHandler,如下所示: ```xml <bean id="dbConfig" class="com.baomidou.mybatisplus.core.config.GlobalConfig.DbConfig"> <property name="typeHandler"> <util:list> <bean class="com.xxx.SqlServerXmlTypeHandler"/> </util:list> </property> </bean> ``` 完成以上配置后,就可以在 Mybatis-Plus 使用 XML 类型了。例如,查询 XML 类型的字段: ```java List<User> userList = userMapper.selectList(new QueryWrapper<User>() .lambda() .select(User::getId, User::getName, User::getXmlContent) .eq(User::getId, 1)); for (User user : userList) { String xmlContent = user.getXmlContent(); // 处理 XML 类型的数据 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

掉发的小王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值