SpringBoot集成Groovy、Mybatis注解 实现动态SQL,帮你摆脱繁琐的XML配置

本文介绍了如何利用SpringBoot的简洁配置、Mybatis的注解以及Groovy来简化动态SQL的处理,避免了XML配置的繁琐。通过在DAO层使用Groovy文件作为Mapper,可以直接在类中编写SQL语句,实现动态SQL与接口方法的完美结合,从而提升代码的可读性和开发效率。
摘要由CSDN通过智能技术生成

SpringBoot的超简洁配置,为我们省去了宝贵的配置时间。

Mybatis3在这方面也提供了很好的支持,通过注解让我们摆脱了繁琐的mapper xml,写DAO层的时候再也不用在java接口和xml配置来回切换了,无疑提升了代码的可读性。

但很不幸,Mybatis3在复杂的动态SQL方面的支持,需要再写**Provider来构建SQL语句,这样的设计感觉有点顾此失彼,本来好端端的通过注解省去了xml配置,但是一遇到动态SQL,又得构建类来处理,让人又爱又恨。看看下面的代码:

package com.syj.test.mybatis;

import com.syj.test.thread.People;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.SelectProvider;
import java.util.List;

/**
 * Created by syj on 2019/2/3.
 */
@Mapper
public interface PeopleDAO {

    //使用UserDaoProvider类的findUserByName方法来生成sql
    @SelectProvider(type = UserDaoProvider.class, method = "findUserByName")
    List<People> findPeople(People people);

    class UserDaoProvider {
        public String findUserByName(People peo) {
            String sql = "SELECT * FROM user";
      
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
SpringBoot可以很容易地集成Groovy。以下是一些步骤来实现SpringBootGroovy集成: 1. 首先,确保你的项目中添加了所需的依赖。你可以在`build.gradle`(如果使用Gradle)或`pom.xml`(如果使用Maven)文件中添加以下依赖项: ```groovy implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org.codehaus.groovy:groovy' implementation 'org.springframework.boot:spring-boot-starter-groovy-templates' ``` 2. 创建一个Groovy脚本文件,比如`GroovyScript.groovy`。在这个脚本中,你可以使用SpringBoot的自动配置和依赖注入功能。 3. 在Groovy脚本中,你可以使用`@Component`注解Groovy类标记为Spring的组件,并且可以使用`@Autowired`注解将其他Spring Bean注入到Groovy类中。你还可以使用`@RestController`注解Groovy类标记为一个REST控制器。 4. 为了在Groovy脚本中获取SpringBoot容器中的Bean,你可以使用`SpringContextUtil`工具类。这个工具类可以通过`SpringApplication.run()`方法启动SpringBoot,并且提供了获取Spring上下文和Bean的方法。 5. 最后,在SpringBoot应用程序的入口类中,你需要启动SpringBoot并加载Groovy脚本。你可以使用`SpringApplication.run()`方法来启动SpringBoot,并将Groovy脚本的路径作为参数传递给它。 通过这些步骤,你可以轻松地将Groovy集成SpringBoot中,并且可以使用SpringBoot的自动配置和依赖注入功能。你可以在Groovy脚本中编写业务逻辑,并且可以通过SpringContextUtil从SpringBoot容器中获取和使用Spring Bean。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值