Springboot+mybatis项目集成SQLite

目前项目是正儿八经的springboot+mybatis连接的sqlserver数据库,因为某些原因想要将数据库换位sqlite并且集成到项目中打一个jar包去运行,请问如何在不动原有结构和代码的情况下去配置修改为sqllite数据库(原有代码逻辑及mybatis sql语句重新修改很麻烦)

xml里面的sql语句,有用到特殊函数的,比如日期处理相关函数,这种不兼容意外,其它都是通用的

当然,wrapper里面也可以拼接sql
建议全局搜索一下常用的函数,然后去测试环境启动后,到处点点点,盲测一番

基本上SQL语句都差不多,你要做的无非是更改DRIVER还有配置文件,但是要注意你之前用sqlserver下业务中写的sql语句,比如查询前几条这样的sql语句 还是和sqlLite有区别的(可参考https://blog.csdn.net/zhouleizhao/article/details/36871455),要去更改适配。
更改点:
meaven用到的jar包:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>2.1.3.RELEASE</version>
    </dependency>
 
    <dependency>
        <groupId>com.bcht.its.das.commons</groupId>
        <artifactId>das-commons-traffic</artifactId>
        <version>1.0</version>
    </dependency>
 
    <dependency>
        <groupId>com.bcht.its.das</groupId>
        <artifactId>das-data-send-rabbitmq</artifactId>
        <version>1.0</version>
    </dependency>
 
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>2.1.2</version>
    </dependency>
 
    <dependency>
        <groupId>org.xerial</groupId>
        <artifactId>sqlite-jdbc</artifactId>
        <version>3.30.1</version>
    </dependency>
 
</dependencies>

配置文件:

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

注意,SQLITE是不需要登录账号的。
配置数据源代码

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.sqlite.SQLiteDataSource;
 
import javax.sql.DataSource;
 
/**
 * <h3>bcht-its-das</h3>
 * <p></p>
 *
 * @author : ZFX
 * @date : 2021-10-12 11:19
 **/
@Configuration
public class MyBatisConfig {
 
    @Value("${spring.datasource.url}")
    private String url;
 
    @Bean(name="dataSource")
    public DataSource dataSource() {
        SQLiteDataSource dataSource = new SQLiteDataSource();
        dataSource.setUrl(url);
        return dataSource;
    }
 
    public SqlSessionFactory sqlSessionFactory() throws Exception {
        SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
        sqlSessionFactoryBean.setDataSource(dataSource());
        return sqlSessionFactoryBean.getObject();
    }
 
}

import org.mybatis.spring.boot.autoconfigure.ConfigurationCustomizer;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
/**
 * <h3>bcht-its-das</h3>
 * <p></p>
 *
 * @author : ZFX
 * @date : 2021-10-12 11:20
 **/
@Configuration
public class MyBatisMapperScannerConfig {
    @Bean
    public MapperScannerConfigurer mapperScannerConfigurer() {
        MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
        mapperScannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactory");
 
        //com.bcht.its.das.mapper 这个包名是所有的Mapper.java文件所在的路径,该包下面的子包里面的文件同样会扫描到。
        //此包名与具体的应用的名称相关
        mapperScannerConfigurer.setBasePackage("com.bcht.its.das.mapper");
 
        return mapperScannerConfigurer;
    }
 
 
    /**
     * 目的防止驼峰命名规则
     *
     * @return
     */
    @Bean
    public ConfigurationCustomizer configurationCustomizer() {
        return new ConfigurationCustomizer() {
            @Override
            public void customize(org.apache.ibatis.session.Configuration configuration) {
                configuration.setMapUnderscoreToCamelCase(true);
            }
        };
    }
 
}

package com.bcht.its.das.mapper;
 
import com.bcht.its.das.entity.ThirdWeatherEntity;
import org.apache.ibatis.annotations.Select;
import org.springframework.stereotype.Service;
 
import java.util.List;
 
/**
 * <h3>bcht-its-das</h3>
 * <p></p>
 *
 * @author : ZFX
 * @date : 2021-10-12 11:22
 **/
@Service
public interface WeatherMapper {
 
    @Select("SELECT * FROM 表名")
    List<ThirdWeatherEntity> selectAll();
 
}

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.scheduling.annotation.EnableScheduling;
 
/**
 * <h3>bcht-its-das</h3>
 * <p>数据抽取</p>
 *
 * @author : ZFX
 * @date : 2021-10-11 10:58
 **/
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
@EnableScheduling
public class Application {
 
    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
 
}

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

内置函数不太一样,(ctrl+shift+R)全局替换一下。

jdbc配置改了,sql中的特殊函数改就 ,完事

依赖中添加sqlite驱动, 数据源的地方 改一下 改成连接sqlite
然后sql 建议备份后 检查一遍, 如果没有使用特殊的内置函数, 旧不用改, 用来那些函数的sql 就需要重新写, 建议使用mubatis的databaseId 数据源驱动厂商标识, 这样可保证程序的兼容性, 后续如果想在改回来 就不用在消耗人力了

https://www.cnblogs.com/desireyang/p/13234985.html 这个比较好