基于Java的泛型和反射实现通用的增删改查(1)——项目搭建

本文介绍了如何基于Java使用IntelliJ IDEA创建一个Gradle项目,通过配置build.gradle和application.yml文件,设置数据源,利用JPA自动创建数据库表,最终实现通用的增删改查功能的项目初始化步骤。
摘要由CSDN通过智能技术生成

 1、使用Idea创建一个gradle项目
  创建时需要填写groupId等信息,这和创建maven项目一样。
 2、创建项目需要的目录结构
  在创建完gradle项目后你会发现Idea并没有像创建maven项目那样为我们生成必要的目录结构,你可以将下面的代码复制到你项目中的build.gradle文件的最后,然后执行create-dirs操作,完成目录结构的创建:

task "create-dirs" << {
    sourceSets*.java.srcDirs*.each{
        it.mkdirs();
    }
    sourceSets*.resources.srcDirs*.each{
        it.mkdirs();
    }
}

  完整的操作步骤如下图所示:
在这里插入图片描述
 3、配置build.gradle文件,添加必要的依赖

apply plugin: 'java'
apply plugin: 'maven'
apply plugin: 'idea'
apply plugin: 'org.springframework.boot'

sourceCompatibility = 1.8
group = 'com.rbl.basement'

def version = '1.0.0.RELEASE'
def artifactId = 'rbl-base'

buildscript{
    ext {
        springBootVersion = '1.5.12.RELEASE'
    }
    repositories {
        maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
    }
}

repositories {
    maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
}

dependencies{
    compile "org.springframework.boot:spring-boot-starter:$springBootVersion"
    compile "org.springframework.boot:spring-boot-starter-web:$springBootVersion"
    compile "org.springframework.boot:spring-boot-starter-data-jpa:$springBootVersion"

    compile 'org.projectlombok:lombok:1.18.10'
    compile 'com.alibaba:fastjson:1.2.7'

    compile 'mysql:mysql-connector-java:5.1.44'
    compile 'com.alibaba:druid:1.1.9'
    compile 'com.alibaba:druid-spring-boot-starter:1.1.9'
}

task sourceJar(type: Jar){
    classifier = 'sources'
    from sourceSets.main.allSource
}

artifacts {
    archives sourceJar
    archives jar
}

//task "create-dirs" << {
//    sourceSets*.java.srcDirs*.each{
//        it.mkdirs();
//    }
//    sourceSets*.resources.srcDirs*.each{
//        it.mkdirs();
//    }
//}

def springVersion = ext.springBootVersion

 4、配置application.yml文件,主要是配置数据源信息,别忘了创建对应的数据库,数据库中的表无需创建,JPA会自动为我们创建

spring:
  jpa:
    hibernate:
      ddl-auto: update
  datasource:
    url: jdbc:mysql://localhost/rbl-base
    username: root
    password: 123456
    driver-class-name: com.mysql.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      initial-size: 5
      min-idle: 5
      max-active: 50
      max-wait: 60000
logging:
  level:
    com.rbl.basement.base: debug
server:
  port: 8080

 5、编写SpringBoot项目的主启动类

@SpringBootApplication
public class RblBaseApplication {
    public static void main(String[] args) {
        SpringApplication.run(RblBaseApplication.class, args);
    }
}

 6、启动项目
  若上面的配置都没有问题的话,此时项目就可以启动了。
 至此,项目搭建就完成了,完整的项目结构如下图:
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在Mybatis中,可以使用通用mapper插件来实现泛型通用增删改查操作。通用mapper插件提供了各种高效的工具,可以简化开发者的工作,提高代码质量和开发效率。 下面是使用通用mapper插件实现泛型通用增删改查的示例代码: 1. 引入通用mapper插件的依赖: ```xml <dependency> <groupId>tk.mybatis</groupId> <artifactId>mapper</artifactId> <version>4.1.5</version> </dependency> ``` 2. 创建实体: ```java public class User { private Long id; private String name; // 省略getter和setter方法 } ``` 3. 创建Mapper接口: ```java @Mapper public interface UserMapper extends tk.mybatis.mapper.common.Mapper<User> { } ``` 4. 在配置文件中配置通用mapper插件: ```xml <configuration> <!-- 其他配置 --> <plugins> <plugin interceptor="tk.mybatis.mapper.autoconfigure.MapperInterceptor"> <property name="mappers" value="tk.mybatis.mapper.common.Mapper"/> </plugin> </plugins> </configuration> ``` 5. 使用通用mapper插件进行增删改查操作: ```java @Autowired private UserMapper userMapper; // 查询所有用户 List<User> userList = userMapper.selectAll(); // 根据主键查询用户 User user = userMapper.selectByPrimaryKey(1L); // 插入用户 User newUser = new User(); newUser.setName("张三"); userMapper.insert(newUser); // 更新用户 User updateUser = new User(); updateUser.setId(1L); updateUser.setName("李四"); userMapper.updateByPrimaryKey(updateUser); // 删除用户 userMapper.deleteByPrimaryKey(1L); ``` 通过以上步骤,我们可以使用通用mapper插件实现泛型通用增删改查操作,避免了大量的SQL编写,提高了开发效率。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值