Sqlite-JDBC查询datetime类型抛异常

使用date类型是会报错Error parsing time stamp

解决方法

  1. Properties传参
Class.forName("org.sqlite.JDBC");
Properties pro = new Properties();
// 默认是yyyy-MM-dd HH:mm:ss.SSS,覆盖为yyyy-MM-dd HH:mm:ss
pro.put("date_string_format", "yyyy-MM-dd HH:mm:ss");

Connection conn = DriverManager.getConnection("jdbc:sqlite:test.db", pro);
// 或者
SQLiteConfig config = new SQLiteConfig();
config.setDateStringFormat("yyyy-MM-dd HH:mm:ss");
Connection conn = DriverManager.getConnection("jdbc:sqlite:sample.db", config.toProperties());

如果使用spring可以通过dataSource的参数注入

<!-- DataSource -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
    <!-- .... -->
    <property name="connectProperties">
        <props>
            <prop key="date_string_format">yyyy-MM-dd HH:mm:ss</prop>
        </props>
    </property>
</bean>
  1. URL传参(推荐)
jdbcUrl=jdbc:sqlite:test.db?date_string_format=yyyy-MM-dd HH:mm:ss
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值