Можно ли преобразовать поле TIMESTAMP в число миллисекунд с эпохи?Преобразование даты в миллисекунды с эпохи с использованием Apache Derby
Что-то вроде:
select
toEpoch(current_timestamp)
from SYSIBM.SYSDUMMY1;
Можно ли преобразовать поле TIMESTAMP в число миллисекунд с эпохи?Преобразование даты в миллисекунды с эпохи с использованием Apache Derby
Что-то вроде:
select
toEpoch(current_timestamp)
from SYSIBM.SYSDUMMY1;
Apache Derby не имеет собственной функции, но это возможно, чтобы создать свой собственный и вызвать его из базы данных.
Во-первых, создать метод Java, который будет конвертировать дату:
package DbExamples.StoredProcedures;
import java.sql.Timestamp;
public class DateUtilities {
public static long toEpoch(Timestamp inputDate) {
if (inputDate == null) {
return 0L;
}
Long result = inputDate.getTime();
return result;
}
}
Затем впрыснуть .jar файл в базу данных, выполнив следующую инструкцию SQL в базе данных:
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');
Теперь создаем хранимую процедуру в базе данных, запустив следующую инструкцию:
drop function toEpoch;
create function toEpoch(inputDate timestamp)
returns bigint
parameter style java no sql
language java external name 'DbExamples.StoredProcedures.DateUtilities.toEpoch';
Теперь вы можете запустить свой запрос:
select
toEpoch(current_timestamp)
from SYSIBM.SYSDUMMY1;
select
toEpoch(cast('2016-07-21 14:50:00' as timestamp))
from SYSIBM.SYSDUMMY1;
Смотрите также: http://stackoverflow.com/q/32581936/193453 и http://stackoverflow.com/q/11017780/193453, которые связаны между собой, но не то же самое. Было бы неплохо собрать все вопросы и ответы «Хранилища Хранилища» Derby как-то ... –
Привет, Брайан, согласен. Просто увидели, что сегодня функция «Документация» переходит на «Бета». Может быть, мы должны это использовать? – Fidel