normanj-bitquill commented on code in PR #3833:
URL: https://github.com/apache/calcite/pull/3833#discussion_r1667195459


##########
core/src/main/java/org/apache/calcite/util/format/postgresql/PostgresqlDateTimeFormatter.java:
##########
@@ -38,90 +45,164 @@ public class PostgresqlDateTimeFormatter {
   @SuppressWarnings("TemporalAccessorGetChronoField")
   private static final FormatPattern[] FORMAT_PATTERNS = new FormatPattern[] {
       new NumberFormatPattern(
-          dt -> {
-            final int hour = dt.get(ChronoField.HOUR_OF_AMPM);
-            return String.format(Locale.ROOT, "%02d", hour == 0 ? 12 : hour);
-          },
-          "HH12"),
-      new NumberFormatPattern(
+          ChronoUnitEnum.HOURS_IN_DAY,
+          0,
+          23,
+          2,
           dt -> String.format(Locale.ROOT, "%02d", dt.getHour()),
           "HH24"),
       new NumberFormatPattern(
+          ChronoUnitEnum.HOURS_IN_HALF_DAY,
+          1,
+          12,
+          2,
           dt -> {
             final int hour = dt.get(ChronoField.HOUR_OF_AMPM);
             return String.format(Locale.ROOT, "%02d", hour == 0 ? 12 : hour);
           },
-          "HH"),
+          "HH12", "HH"),
       new NumberFormatPattern(
+          ChronoUnitEnum.MINUTES_IN_HOUR,
+          0,
+          59,
+          2,
           dt -> String.format(Locale.ROOT, "%02d", dt.getMinute()),
           "MI"),
       new NumberFormatPattern(
+          ChronoUnitEnum.SECONDS_IN_DAY,
+          0,
+          24 * 60 * 60 - 1,
+          5,
           dt -> Integer.toString(dt.get(ChronoField.SECOND_OF_DAY)),
-          "SSSSS", "SSSS"),
+          "SSSSS"),
       new NumberFormatPattern(
+          ChronoUnitEnum.SECONDS_IN_DAY,
+          0,
+          9999,
+          4,
+          dt -> Integer.toString(dt.get(ChronoField.SECOND_OF_DAY)),
+          "SSSS"),
+      new NumberFormatPattern(
+          ChronoUnitEnum.SECONDS_IN_MINUTE,
+          0,
+          59,
+          2,
           dt -> String.format(Locale.ROOT, "%02d", dt.getSecond()),
           "SS"),
       new NumberFormatPattern(
+          ChronoUnitEnum.MILLIS,
+          0,
+          999,
+          3,
           dt -> String.format(Locale.ROOT, "%03d", 
dt.get(ChronoField.MILLI_OF_SECOND)),
           "MS"),
       new NumberFormatPattern(
+          ChronoUnitEnum.MICROS,
+          0,
+          999_999,
+          6,
           dt -> String.format(Locale.ROOT, "%06d", 
dt.get(ChronoField.MICRO_OF_SECOND)),
           "US"),
       new NumberFormatPattern(
+          ChronoUnitEnum.TENTHS_OF_SECOND,
+          0,
+          9,
+          1,
           dt -> Integer.toString(dt.get(ChronoField.MILLI_OF_SECOND) / 100),
           "FF1"),
       new NumberFormatPattern(
+          ChronoUnitEnum.HUNDREDTHS_OF_SECOND,
+          0,
+          99,
+          2,
           dt -> String.format(Locale.ROOT, "%02d", 
dt.get(ChronoField.MILLI_OF_SECOND) / 10),
           "FF2"),
       new NumberFormatPattern(
+          ChronoUnitEnum.THOUSANDTHS_OF_SECOND,
+          0,
+          999,
+          3,
           dt -> String.format(Locale.ROOT, "%03d", 
dt.get(ChronoField.MILLI_OF_SECOND)),
           "FF3"),
       new NumberFormatPattern(
+          ChronoUnitEnum.TENTHS_OF_MS,
+          0,
+          9_999,
+          4,
           dt -> String.format(Locale.ROOT, "%04d", 
dt.get(ChronoField.MICRO_OF_SECOND) / 100),
           "FF4"),
       new NumberFormatPattern(
+          ChronoUnitEnum.HUNDREDTHS_OF_MS,
+          0,
+          99_999,
+          5,
           dt -> String.format(Locale.ROOT, "%05d", 
dt.get(ChronoField.MICRO_OF_SECOND) / 10),
           "FF5"),
       new NumberFormatPattern(
+          ChronoUnitEnum.THOUSANDTHS_OF_MS,
+          0,
+          999_999,
+          6,
           dt -> String.format(Locale.ROOT, "%06d", 
dt.get(ChronoField.MICRO_OF_SECOND)),
           "FF6"),
-      new EnumStringFormatPattern(ChronoField.AMPM_OF_DAY, "AM", "PM"),
-      new EnumStringFormatPattern(ChronoField.AMPM_OF_DAY, "am", "pm"),
-      new EnumStringFormatPattern(ChronoField.AMPM_OF_DAY, "A.M.", "P.M."),
-      new EnumStringFormatPattern(ChronoField.AMPM_OF_DAY, "a.m.", "p.m."),
-      new NumberFormatPattern(dt -> {
-        final String formattedYear = String.format(Locale.ROOT, "%0,4d", 
dt.getYear());
-        if (formattedYear.length() == 4 && formattedYear.charAt(0) == '0') {
-          return "0," + formattedYear.substring(1);
-        } else {
-          return formattedYear;
-        }
-      }, "Y,YYY") {
-        @Override protected String trimLeadingZeros(String value) {
-          return value;
-        }
-      },
-      new NumberFormatPattern(
+      new EnumStringFormatPattern(
+          ChronoUnitEnum.HALF_DAYS,
+          ChronoField.AMPM_OF_DAY,
+          "AM", "PM"),
+      new EnumStringFormatPattern(
+          ChronoUnitEnum.HALF_DAYS,
+          ChronoField.AMPM_OF_DAY,
+          "am", "pm"),
+      new EnumStringFormatPattern(
+          ChronoUnitEnum.HALF_DAYS,
+          ChronoField.AMPM_OF_DAY,
+          "A.M.", "P.M."),
+      new EnumStringFormatPattern(
+          ChronoUnitEnum.HALF_DAYS,
+          ChronoField.AMPM_OF_DAY,
+          "a.m.", "p.m."),
+      new YearWithCommasFormatPattern(),
+      new NumberFormatPattern(
+          ChronoUnitEnum.YEARS,
+          0,
+          Integer.MAX_VALUE,
+          4,
           dt -> String.format(Locale.ROOT, "%04d", dt.getYear()),
           "YYYY"),
       new NumberFormatPattern(
+          ChronoUnitEnum.YEARS_ISO_8601,
+          0,
+          Integer.MAX_VALUE,
+          4,
           dt -> Integer.toString(dt.get(IsoFields.WEEK_BASED_YEAR)),
           "IYYY"),
       new NumberFormatPattern(
+          ChronoUnitEnum.YEARS_IN_MILLENIA_ISO_8601,
+          0,
+          Integer.MAX_VALUE,
+          3,
           dt -> {
             final String yearString =
                 String.format(Locale.ROOT, "%03d", 
dt.get(IsoFields.WEEK_BASED_YEAR));
             return yearString.substring(yearString.length() - 3);
           },
           "IYY"),
       new NumberFormatPattern(
+          ChronoUnitEnum.YEARS_IN_CENTURY_ISO_8601,
+          0,
+          Integer.MAX_VALUE,

Review Comment:
   Turns out that PostgreSQL does not limit this. It will accept 4 digit 
numbers.



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: commits-unsubscr...@calcite.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org

Reply via email to