gpt4 book ai didi

sql - 使用 Apache Derby 转换日期

转载 作者:行者123 更新时间:2023-12-02 09:46:48 25 4
gpt4 key购买 nike

我有一个日期存储在以下格式的 varchar 字段中:

3 Jun 2016

我想将它转换为另一个 varchar,这次是这种格式:
2016-06-03 00:00:00.000

我需要第二种格式的原因是为了与某个 API 进行交互。

附言。 This other SO question类似,但仅涉及格式化存储为数据库中日期的字段。我的问题是将存储为字符串的日期转换为存储为字符串的另一个日期。

最佳答案

Apache Derby 没有 native 函数,但可以创建自己的函数并从数据库中调用它。

首先,创建将转换日期的 java 方法:

package DbExamples.StoredProcedures;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

public class DateUtilities {

public static String convertDate(String inputDateString, String currentFormat, String outputFormatString) throws ParseException {
SimpleDateFormat inputFormat = new SimpleDateFormat(currentFormat);
Date inputDate = inputFormat.parse(inputDateString);

SimpleDateFormat outputFormat = new SimpleDateFormat(outputFormatString);
String result = outputFormat.format(inputDate);

return result;
}
}

然后通过在数据库上运行以下 sql 语句将 jar 文件注入(inject)数据库:
CALL SQLJ.REMOVE_JAR('App.StoredProcedures', 0);
CALL SQLJ.INSTALL_JAR('C:\dev\DbExamples\dist\DbExamples.jar', 'App.StoredProcedures', 0);
CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY('derby.database.classpath', 'App.StoredProcedures');

现在通过运行以下 sql 语句在数据库中创建存储过程:
drop function convertDate;
create function convertDate(dateString varchar(8000), currentFormat varchar(8000), outputFormat varchar(8000))
returns varchar(8000)
parameter style java no sql
language java external name 'DbExamples.StoredProcedures.DateUtilities.convertDate';

现在您可以运行查询:
select
convertDate('3 Jun 2016', 'd MMM yyyy', 'yyyy-MM-dd HH:mm:ss.SSS') as dt
from SYSIBM.SYSDUMMY1;

返回:
2016-06-03 00:00:00.000

事实上,该技术甚至可以用于将 varchar 转换为 TIMESTAMP:
select
cast(convertDate('3 Jun 2016', 'd MMM yyyy', 'yyyy-MM-dd HH:mm:ss.SSS') as timestamp) as dt
from SYSIBM.SYSDUMMY1;

关于sql - 使用 Apache Derby 转换日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38393750/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com