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

作者:evasnowind 时间:2022-11-16 12:05:09 

本文主要关注如何使用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

来源:https://blog.csdn.net/evasnowind/article/details/104626336

标签:spring,mybatisplus,sqlserver
0
投稿

猜你喜欢

  • Android自定义scrollview实现回弹效果

    2023-12-15 08:42:47
  • java类加载机制、类加载器、自定义类加载器的案例

    2023-02-06 07:35:33
  • Java8时间api之LocalDate/LocalDateTime的用法详解

    2023-11-10 16:14:43
  • swagger中如何给请求添加header

    2023-05-15 14:27:52
  • C#实现数据包加密与解密实例详解

    2022-05-14 18:44:50
  • SpringMVC入门实例

    2023-02-04 12:43:48
  • Android AutoCompleteTextView控件基本用法示例

    2022-04-05 08:53:43
  • C#简单实现文件上传功能

    2022-10-03 17:29:41
  • Android触摸及手势操作GestureDetector

    2023-07-31 14:13:42
  • Android中的windowSoftInputMode属性详解

    2022-11-14 06:17:40
  • 详解Java类库的概念以及import的使用方法

    2022-04-18 06:56:54
  • Java Apache Shiro安全框架快速开发详解流程

    2022-06-21 23:00:23
  • C#面向对象编程之猜拳游戏实现方法

    2021-11-17 23:25:52
  • Android编程实现ActionBar的home图标动画切换效果

    2021-11-21 11:34:11
  • Flutter 如何正确显示SnackBar

    2023-06-23 13:00:40
  • RxJava+Retrofit+OkHttp实现多文件下载之断点续传

    2023-07-19 22:32:35
  • Java CompletableFuture 异步超时实现深入研究

    2022-12-28 04:18:14
  • 一键清除maven仓库中下载失败的jar包的实现方法

    2023-08-13 03:43:59
  • Android ProgressDialog使用总结

    2023-07-10 22:16:33
  • springboot集成@DS注解实现数据源切换的方法示例

    2021-11-18 11:30:00
  • asp之家 软件编程 m.aspxhome.com