Postgresql周日的Java常量

时间:2018-05-18 06:14:18

标签: java postgresql dayofweek

Postgresql使用EXTRACTdow以下列方式返回星期几:0表示星期日,1表示星期一,一直到6表示星期六see official documentation

我正在寻找一些Java本身或JDBC中的官方常量,或者是一些符合此编号的标准库(Apache Commons?)。

3 个答案:

答案 0 :(得分:4)

根据相同的official documentation,您应该使用isodow

星期一(1)到星期日(7)的星期几

答案 1 :(得分:1)

TL;博士

  

我正在寻找Java正确的官方常量

是的,Java使用与Postgres中的isodow函数相同的标准ISO 8601定义来定义DayOfWeek枚举中的七个星期值,其中一周从周一到周日运行几天编号1-7。

DayOfWeek.WEDNESDAY.getValue()  // Returns an `int` 1-7 for Monday-Sunday. 
  

3

java.time.DayOfWeek枚举

Answer by Rcordoval所示,请使用Postgres function isodow

isodow中的“iso”表示ISO 8601标准和its definition of week,其中星期一至星期日的日期编号为1-7。

Java在其DayOfWeek枚举中支持相同的周定义。该类为您定义了七个对象,一个用于一周中的每一天,例如DayOfWeek.MONDAY。要获取每个对象的星期几编号,周一至周日的1-7,请致电DayOfWeek::getValue。但是在Java编码中,请专注于使用和传递DayOfWeek个对象本身,而不仅仅是整数。

int dowNumber = DayOfWeek.WEDNESDAY.getValue() ;
  

3

从整数到DayOfWeek对象有点棘手,因为我们需要使用索引访问Java数组。索引表示从零开始计数,因此从您的星期数中减去一个。星期三是第3天,因此减去1以获得2的结果以访问DayOfWeek.WEDNESDAY

DayOfWeek dow = DayOfWeek.values()[ 3-1 ] ;  // Get object named `WEDNESDAY` using zero-based index counting, so 3 - 1 = 2.
  

dow.toString():WEDNESDAY

顺便说一下,要自动本地化星期几的名称,请致电DayOfWeek::getDisplayName

Java而不是SQL

  

我目前正在编写一个查询,查找目前在各自时区的星期五上午10:00的客户,因此我需要将“星期五”的概念传递给查询,当然我不会想要硬编码。

使用业界领先的 java.time 类而不是SQL,可能更好地在Java中完成这项工作。

你必须非常小心时区。明确时区而不是依赖隐式默认区域。

时区对于确定日期至关重要。对于任何给定的时刻,日期在全球范围内因地区而异。例如,在Paris France午夜后的几分钟是新的一天,而Montréal Québec中仍然是“昨天”。

如果未指定时区,则JVM会隐式应用其当前的默认时区。该默认值可能随时更改,因此您的结果可能会有所不同。最好明确指定您期望/预期的时区作为参数。

continent/region的格式指定proper time zone name,例如America/MontrealAfrica/CasablancaPacific/Auckland。切勿使用诸如ESTIST之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。

ZoneId z = ZoneId.of( "America/Montreal" ) ;  
LocalDate today = LocalDate.now( z ) ;

如果要使用JVM的当前默认时区,请求它并作为参数传递。如果省略,则隐式应用JVM的当前默认值。最好是明确的,因为默认情况下可以在运行时期间由JVM中任何应用程序的任何线程中的任何代码随时更改

ZoneId z = ZoneId.systemDefault() ;  // Get JVM’s current default time zone.

接下来,请参加下周五,或者如果已经是星期五那么坚持今天。使用TemporalAdjuster在日期之间进行调整,尤其是在TemporalAdjusters中找到的日期。

LocalDate nextOrSameFriday = today.with( TemporalAdjusters.nextOrSame( DayOfWeek.FRIDAY ) ) ;

你说你的目标是上午10点。

LocalTime lt = LocalTime.of( 10 , 0 ) ;  // 10 AM.

与日期和区域结合以获得特定时刻。

ZonedDateTime zdt = ZonedDateTime.of( ld , lt , z ) ;

通过提取Instant对象调整为UTC。同一时刻,时间轴上的相同点,但不同的挂钟时间。

Instant instant = zdt.toInstant() ;

制定SQL以查询类型为TIMESTAMP WITH TIME ZONE的数据库列。

String sql = "SELECT * from tbl WHERE when_col = ? ; " ;
…
myPreparedStatement.setObject( … , instant ) ;

并检索。

Instant instant = myResultSet.getObject( … , Instant.class ) ;
ZonedDateTime zdt = instant.atZone( z ) ;

在这种方法中,您需要Postgres中的dowisodow函数。

关于 java.time

java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time类。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310

您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*类。

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore

答案 2 :(得分:0)

您可以使用Calendar常量减1来匹配PostgreSQL值,即:Calendar.SUNDAY = 1