当前位置:   article > 正文

spring boot + mybatis + sqlite3_springboot mybatis sqlite

springboot mybatis sqlite

spring boot + mybatis + sqlite3

引言

sqlite 的描述:SQLite 是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是在世界上最广泛部署的 SQL 数据库引擎。SQLite 源代码不受版权限制。简而言之,sqlite是一个本地的轻量级数据库,不需要用户名,密码,直接就可以对数据库进行操作,主要是用在嵌入式产品中。

在搭建spring boot + sqlite3 框架过程中,遇到一些问题。把解决方法记录下来。

1.maven用到的jar包:

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. <version>2.1.3.RELEASE</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>com.bcht.its.das.commons</groupId>
  9. <artifactId>das-commons-traffic</artifactId>
  10. <version>1.0</version>
  11. </dependency>
  12. <dependency>
  13. <groupId>com.bcht.its.das</groupId>
  14. <artifactId>das-data-send-rabbitmq</artifactId>
  15. <version>1.0</version>
  16. </dependency>
  17. <dependency>
  18. <groupId>org.mybatis.spring.boot</groupId>
  19. <artifactId>mybatis-spring-boot-starter</artifactId>
  20. <version>2.1.2</version>
  21. </dependency>
  22. <dependency>
  23. <groupId>org.xerial</groupId>
  24. <artifactId>sqlite-jdbc</artifactId>
  25. <version>3.30.1</version>
  26. </dependency>
  27. </dependencies>

2.配置文件:

  1. ## 数据库配置
  2. spring.datasource.driver-class-name=org.sqlite.JDBC
  3. spring.datasource.url=jdbc:sqlite:E:/worktool/sqlite-dll-win64-x64-3360000/demo.db
  4. spring.datasource.username=
  5. spring.datasource.password=

注意,SQLITE是不需要登录账号的。

3.配置数据源代码

  1. import org.apache.ibatis.session.SqlSessionFactory;
  2. import org.mybatis.spring.SqlSessionFactoryBean;
  3. import org.springframework.beans.factory.annotation.Value;
  4. import org.springframework.context.annotation.Bean;
  5. import org.springframework.context.annotation.Configuration;
  6. import org.sqlite.SQLiteDataSource;
  7. import javax.sql.DataSource;
  8. /**
  9. * <h3>bcht-its-das</h3>
  10. * <p></p>
  11. *
  12. * @author : ZFX
  13. * @date : 2021-10-12 11:19
  14. **/
  15. @Configuration
  16. public class MyBatisConfig {
  17. @Value("${spring.datasource.url}")
  18. private String url;
  19. @Bean(name="dataSource")
  20. public DataSource dataSource() {
  21. SQLiteDataSource dataSource = new SQLiteDataSource();
  22. dataSource.setUrl(url);
  23. return dataSource;
  24. }
  25. public SqlSessionFactory sqlSessionFactory() throws Exception {
  26. SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
  27. sqlSessionFactoryBean.setDataSource(dataSource());
  28. return sqlSessionFactoryBean.getObject();
  29. }
  30. }
  1. import org.mybatis.spring.boot.autoconfigure.ConfigurationCustomizer;
  2. import org.mybatis.spring.mapper.MapperScannerConfigurer;
  3. import org.springframework.context.annotation.Bean;
  4. import org.springframework.context.annotation.Configuration;
  5. /**
  6. * <h3>bcht-its-das</h3>
  7. * <p></p>
  8. *
  9. * @author : ZFX
  10. * @date : 2021-10-12 11:20
  11. **/
  12. @Configuration
  13. public class MyBatisMapperScannerConfig {
  14. @Bean
  15. public MapperScannerConfigurer mapperScannerConfigurer() {
  16. MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
  17. mapperScannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactory");
  18. //com.bcht.its.das.mapper 这个包名是所有的Mapper.java文件所在的路径,该包下面的子包里面的文件同样会扫描到。
  19. //此包名与具体的应用的名称相关
  20. mapperScannerConfigurer.setBasePackage("com.bcht.its.das.mapper");
  21. return mapperScannerConfigurer;
  22. }
  23. /**
  24. * 目的防止驼峰命名规则
  25. *
  26. * @return
  27. */
  28. @Bean
  29. public ConfigurationCustomizer configurationCustomizer() {
  30. return new ConfigurationCustomizer() {
  31. @Override
  32. public void customize(org.apache.ibatis.session.Configuration configuration) {
  33. configuration.setMapUnderscoreToCamelCase(true);
  34. }
  35. };
  36. }
  37. }
  1. package com.bcht.its.das.mapper;
  2. import com.bcht.its.das.entity.ThirdWeatherEntity;
  3. import org.apache.ibatis.annotations.Select;
  4. import org.springframework.stereotype.Service;
  5. import java.util.List;
  6. /**
  7. * <h3>bcht-its-das</h3>
  8. * <p></p>
  9. *
  10. * @author : ZFX
  11. * @date : 2021-10-12 11:22
  12. **/
  13. @Service
  14. public interface WeatherMapper {
  15. @Select("SELECT * FROM 表名")
  16. List<ThirdWeatherEntity> selectAll();
  17. }
  1. import org.springframework.boot.SpringApplication;
  2. import org.springframework.boot.autoconfigure.SpringBootApplication;
  3. import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
  4. import org.springframework.scheduling.annotation.EnableScheduling;
  5. /**
  6. * <h3>bcht-its-das</h3>
  7. * <p>数据抽取</p>
  8. *
  9. * @author : ZFX
  10. * @date : 2021-10-11 10:58
  11. **/
  12. @SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
  13. @EnableScheduling
  14. public class Application {
  15. public static void main(String[] args) {
  16. SpringApplication.run(Application.class,args);
  17. }
  18. }

使用的方式就和其他数据源使用MyBatis一样

如果项目构建完成,发现idea启动报错无法建立到数据库的connection连接,大概率是IDEA没有SQLITE的插件,安装下插件即可。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/704100
推荐阅读
相关标签
  

闽ICP备14008679号