spring中使用mybatis plus连接sqlserver的方法实现

 更新时间:2020年12月28日 11:53:03   作者:evasnowind  
这篇文章主要介绍了spring中使用mybatis plus连接sqlserver的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

本文主要关注如何使用mybatis/mybatis plus连接SQL Server数据库,因此将省略其他项目配置、代码。

框架选择

应用框架:spring boot
ORM框架:mybatis plus(对于连接数据库而言,mybatis和mybatis plus其实都一样)
数据库连接池:druid

pom依赖

此处仅给出我的配置,mybatis/druid请依据自己项目的需要进行选择。
方便起见我用的是mybatis plus

    <!--mybatis plus -->
    <dependency>
      <groupId>com.baomidou</groupId>
      <artifactId>mybatis-plus-boot-starter</artifactId>
      <version>3.1.0</version>
    </dependency>
    
    <dependency>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-core</artifactId>
      <version>1.3.7</version>
    </dependency>
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>2.0.0</version>
    </dependency>

    <!-- druid 连接池 -->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid</artifactId>
      <version>1.1.12</version>
    </dependency>

    <!--for SqlServer-->
    <dependency>
      <groupId>com.microsoft.sqlserver</groupId>
      <artifactId>sqljdbc4</artifactId>
      <version>4.0</version>
    </dependency>

配置数据源

添加数据库配置

YAML文件中添加自己数据库的地址

# SQL Server数据库
spring.datasource.xx.url: jdbc:sqlserver://你的数据库地址:1433;databaseName=你的数据库名称
spring.datasource.xx.username: xxxx
spring.datasource.xx.password: xxxx
spring.datasource.xx.driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver

添加数据源

此处和平时我们在spring boot中集成mybatis/mybatis plus一样,添加bean即可。
由于平时经常用到多个数据库,此处展示一个多数据源的例子:一个是mysql,一个是SQL Server
有关mybatis plus配置数据源的注意事项,比如配置mapper文件夹等,请自行问度娘,此处不再一一指出。
注意:下面代码来自实际代码,但批量删除了敏感信息、重新命名,因而可能存在与前面配置信息不一致的地方,仅仅是一个示例

Mysql数据源

mysql数据源配置,注意,由于是多数据源,需要有一个数据源配置中加上@Primary注解

@Configuration
@MapperScan(basePackages = "com.xxx.mapper", sqlSessionFactoryRef = "mysqlSqlSessionFactory")
public class MySQLMybatisPlusConfig {

  @Autowired
  private MybatisPlusProperties properties;

  @Autowired
  private ResourceLoader resourceLoader = new DefaultResourceLoader();

  @Autowired(required = false)
  private Interceptor[] interceptors;

  @Autowired(required = false)
  private DatabaseIdProvider databaseIdProvider;

  @Autowired
  private Environment env;

  @Bean(name = "mysqlDataSource")
  @Primary
  public DataSource getRecruitDataSource() throws Exception {
    Properties props = new Properties();
    props.put("driverClassName", env.getProperty("spring.datasource.mysqlData.driver-class-name"));
    props.put("url", env.getProperty("spring.datasource.mysqlData.url"));
    props.put("username", env.getProperty("spring.datasource.mysqlData.username"));
    props.put("password", env.getProperty("spring.datasource.mysqlData.password"));
    return DruidDataSourceFactory.createDataSource(props);
  }

  /**
   * mybatis-plus分页插件
   */
  @Bean
  public PaginationInterceptor paginationInterceptor() {
    PaginationInterceptor page = new PaginationInterceptor();
    page.setDialectType("mysql");
    return page;
  }

  @Bean(name = "mysqlSqlSessionFactory")
  @Primary
  public MybatisSqlSessionFactoryBean mybatisSqlSessionFactoryBean(@Qualifier("mysqlDataSource") DataSource mysqlDataSource) throws IOException {
    MybatisSqlSessionFactoryBean mybatisPlus = new MybatisSqlSessionFactoryBean();
    try {
      mybatisPlus.setDataSource(mysqlDataSource);
    } catch (Exception e) {
      e.printStackTrace();
    }
    mybatisPlus.setVfs(SpringBootVFS.class);
    // 设置分页插件
    MybatisConfiguration mc = new MybatisConfiguration();
    mc.setDefaultScriptingLanguage(MybatisXMLLanguageDriver.class);
    mc.setMapUnderscoreToCamelCase(true);// 数据库和java都是驼峰,就不需要
    mybatisPlus.setConfiguration(mc);
    if (this.databaseIdProvider != null) {
      mybatisPlus.setDatabaseIdProvider(this.databaseIdProvider);
    }
    mybatisPlus.setTypeAliasesPackage("com.xxx.mysql.bean.model");
    mybatisPlus.setTypeHandlersPackage(this.properties.getTypeHandlersPackage());
    mybatisPlus.setMapperLocations(this.properties.resolveMapperLocations());
    // 设置mapper.xml文件的路径
    ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
    Resource[] resource = resolver.getResources("classpath:mapper/*.xml");
    mybatisPlus.setMapperLocations(resource);

    return mybatisPlus;
  }
}

SQL Server数据源

@Configuration
@MapperScan(basePackages = "com.xxx.survey.mapper", sqlSessionFactoryRef = "xxSqlSessionFactory")
public class SqlServerMybatisConfig {

  @Autowired
  private MybatisPlusProperties properties;

  @Autowired
  private ResourceLoader resourceLoader = new DefaultResourceLoader();

  @Autowired(required = false)
  private Interceptor[] interceptors;

  @Autowired(required = false)
  private DatabaseIdProvider databaseIdProvider;

  @Autowired
  private Environment env;

  @Bean(name = "xxDataSource")
  public DataSource getAttendanceDataSource() throws Exception {
    Properties props = new Properties();
    props.put("driverClassName", env.getProperty("spring.datasource.xx.driver-class-name"));
    props.put("url", env.getProperty("spring.datasource.xx.url"));
    props.put("username", env.getProperty("spring.datasource.xx.username"));
    props.put("password", env.getProperty("spring.datasource.xx.password"));
    return DruidDataSourceFactory.createDataSource(props);
  }


  @Bean(name = "xxSqlSessionFactory")
  public MybatisSqlSessionFactoryBean mybatisSqlSessionFactoryBean(@Qualifier("xxDataSource") DataSource xxDataSource) throws IOException {
    MybatisSqlSessionFactoryBean mybatisPlus = new MybatisSqlSessionFactoryBean();
    try {
      mybatisPlus.setDataSource(xxDataSource);
    } catch (Exception e) {
      e.printStackTrace();
    }
    mybatisPlus.setVfs(SpringBootVFS.class);
    // 设置分页插件
    MybatisConfiguration mc = new MybatisConfiguration();
    mc.setDefaultScriptingLanguage(MybatisXMLLanguageDriver.class);
    mc.setMapUnderscoreToCamelCase(true);// 数据库和java都是驼峰,就不需要
    mybatisPlus.setConfiguration(mc);
    if (this.databaseIdProvider != null) {
      mybatisPlus.setDatabaseIdProvider(this.databaseIdProvider);
    }
    mybatisPlus.setTypeAliasesPackage("com.xxx.survey.bean.model");
    mybatisPlus.setTypeHandlersPackage(this.properties.getTypeHandlersPackage());
    mybatisPlus.setMapperLocations(this.properties.resolveMapperLocations());
    // 设置mapper.xml文件的路径
    ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
    Resource[] resource = resolver.getResources("classpath:mapper/*.xml");
    mybatisPlus.setMapperLocations(resource);

    return mybatisPlus;
  }
}

生成ORM代码

到这里,程序启动应该没什么问题,接着就应该生成DAO层、Service层代码了
mybatis和mybatis plus在此处按照和连接mysql时一样的方法,根据需要写代码即可。
比如对于mybatis plus,需要写3处代码:

实体bean,可以利用Spring Boot Code Generator!来根据SQL表结构自动生成

Mapper代码:都有模板,mybatis plus自己封装的方法已经很够用,有单独需求可以自己写xml来自定义SQL

@Mapper
public interface XXXMapper extends BaseMapper<XXX> {

}

Service代码
好像也有现成的工具可以自动生成mapper service代码来着。
Service接口

public interface XXXService extends IService<XXX> {
}

ServiceImpl

@Service
public class XXXServiceImpl extends ServiceImpl<XXXMapper, XXX>
  implements XXXService {
}

参考资料

Spring Boot 集成 MyBatis和 SQL Server实践
springboo-mybatis SQL Server

到此这篇关于spring中使用mybatis plus连接sqlserver的方法实现的文章就介绍到这了,更多相关spring连接sqlserver内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java Swing的层次结构深入理解

    Java Swing的层次结构深入理解

    这篇文章主要介绍了Java Swing的层次结构深入理解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Spring boot跨域设置实例详解

    Spring boot跨域设置实例详解

    这篇文章主要介绍了Spring boot跨域设置实例详解,简单介绍了跨域的定义,原因,使用场景及解决方案,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • Java使用正则获取括号里面的内容

    Java使用正则获取括号里面的内容

    这篇文章主要介绍了Java使用正则获取括号里面的内容问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • Java判断上传图片格式的实例代码

    Java判断上传图片格式的实例代码

    这篇文章主要介绍了Java判断上传图片格式的实例代码,在文中给大家提到了Java使用文件头的类型判断上传的文件是否为图片类型,需要的朋友可以参考下
    2019-06-06
  • Java单例模式下的MongoDB数据库操作工具类

    Java单例模式下的MongoDB数据库操作工具类

    这篇文章主要介绍了Java单例模式下的MongoDB数据库操作工具类,结合实例形式分析了java基于单例模式下操作MongoDB数据库相关连接、查询、插入、删除等操作封装技巧,需要的朋友可以参考下
    2018-01-01
  • Spring使用@Async出现循环依赖原因及解决方案分析

    Spring使用@Async出现循环依赖原因及解决方案分析

    在Spring框架中,启用异步功能需要在应用主类上添加@EnableAsync注解,当项目中存在循环引用时,如一个异步类MessageService和一个常规类TaskService相互引用,并且这两个类位于同一包内,这种情况下可能会触发Spring的循环依赖异常
    2024-10-10
  • 详解Spring 中 Bean 的生命周期

    详解Spring 中 Bean 的生命周期

    这篇文章主要介绍了Spring 中 Bean 的生命周期的相关资料,帮助大家更好的理解和使用spring框架,感兴趣的朋友可以了解下。
    2021-01-01
  • java课程设计做一个多人聊天室(socket+多线程)

    java课程设计做一个多人聊天室(socket+多线程)

    这篇文章主要介绍了我的java课程设计一个多人聊天室(socket+多线程)本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • Lambda表达式和Java集合框架

    Lambda表达式和Java集合框架

    本文主要介绍了Lambda表达式和Java集合框架的相关知识,具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • 一文快速掌握Java中的搜索算法和排序算法

    一文快速掌握Java中的搜索算法和排序算法

    这篇文章主要为大家详细介绍了Java中常用的搜索算法和排序算法的实现,例如二分查找、冒泡排序、选择排序等,文中的示例代码讲解详细,希望对大家有所帮助
    2023-04-04

最新评论