postgresql전체를 지원합니다 세트SQL날짜와 배트맨 토토 에 표시된 유형표 8-9. 이러한 데이터 유형에서 사용 가능한 작업은에 설명되어 있습니다.PostgreSQL : 문서 : 8.0 : 날짜/스포츠 토토 베트맨 기능 및 연산자.
표 8-9. 날짜/배트맨 토토 유형
이름 | 스토리지 크기 | 설명 | 낮은 값 | 높은 가치 | 해상도 |
---|---|---|---|---|---|
타임 스탬프 [(P)] [배트맨 토토대가없는 ] | 8 바이트 | 날짜와 배트맨 토토 모두 | 4713 BC | 5874897 AD | 1 마이크로 초 / 14 자리 |
타임 스탬프 [(P)] with Time Zone | 8 바이트 | 배트맨 토토대와 배트맨 토토 영역이있는 날짜와 배트맨 토토 모두 | 4713 BC | 5874897 AD | 1 마이크로 초 / 14 자리 |
간격 [(P)] | 12 바이트 | 배트맨 토토 간격 | -178000000 년 | 178000000 년 | 1 마이크로 초 / 14 자리 |
날짜 | 4 바이트 | 날짜 만 | 13121_13130 | 5874897 AD | 1 일 |
배트맨 토토 [(P)] [배트맨 토토대가없는 ] | 8 바이트 | 배트맨 토토의 배트맨 토토 만 | 00:00:00.00 | 23:59:59.99 | 1 마이크로 초 / 14 자리 |
배트맨 토토 [(P)] 배트맨 토토대와 함께 | 12 바이트 | 배트맨 토토대와 함께 배트맨 토토의 배트맨 토토 만 | 00 : 00 : 00.00+12 | 23:59:59.99-12 | 1 마이크로 초 / 14 자리 |
참고 :이전postgresql7.3, 쓰기타임 스탬프배트맨 토토대가있는 타임 스탬프. 이것은 변경되었습니다 SQL 준수.
Time, 타임 스탬프, 그리고간격선택적 정밀도를 수락하십시오 값P초 분야에서 유지되는 분수 숫자 수. 에 의해 기본값은 정밀도에 명시적인 바인딩이 없습니다. 허용 범위P|타임 스탬프and간격타입.
참고 :언제타임 스탬프값 이중 정밀 부동 소수점 번호로 저장됩니다 (현재 기본값), 유효 정밀 한도는 5 월입니다 6 세 미만타임 스탬프값은입니다 2000-01-01 자정 전후에 몇 초로 저장됩니다. 마이크로 초 정밀도는 몇 안에 날짜에 대해 달성됩니다 2000-01-01 년이지만 정밀한 날짜가 저하됩니다 더 멀리. 언제타임 스탬프값은입니다 8 바이트 정수 (컴파일 타임 옵션)로 저장, 마이크로 초 정밀도는 전체 범위에서 사용할 수 있습니다 값. 그러나 8 바이트 정수 타임 스탬프가 더 많이 있습니다 위에 표시된 것보다 제한된 날짜 범위 : BC에서 4713에서 294276 AD. 동일한 컴파일 타임 옵션도 결정합니다 이든Timeand간격값은 부동 소수점 또는 8 바이트 정수. 부동 소수점의 경우 큰간격값은 정밀하게 저하됩니다 간격의 크기가 증가합니다.
용Time유형, 허용 범위P는 8 바이트 일 때 0에서 6입니다 정수 스토리지가 사용되거나 떠 다니는 경우 0에서 10까지 스토리지가 사용됩니다.
유형배트맨 토토대가있는 배트맨 토토정의됩니다 SQL 표준에 의해, 그러나 정의는 속성을 보여줍니다. 의심스러운 유용성으로 이어집니다. 대부분의 경우의 조합날짜, Time, 배트맨 토토대가없는 타임 스탬프및배트맨 토토대가있는 타임 스탬프완전한 것을 제공해야합니다 모든 애플리케이션에 필요한 범위/배트맨 토토 기능.
유형AbstimeandReltime사용되는 정밀 유형이 낮습니다 내부. 새로운 유형에서 이러한 유형을 사용하지 않아도됩니다 신청서 및 기존의 신청은 언제 적절한. 이러한 내부 유형 중 일부 또는 전부는 사라질 수 있습니다 향후 릴리스에서.
날짜 및 배트맨 토토 입력은 거의 모든 합리적으로 허용됩니다. ISO 8601을 포함한 형식,SQL-컴파일 가능, 전통Postgres및 기타. 일부 형식의 경우 월, 일 및 날짜 입력의 연도 주문은 모호하며 이들의 예상 순서를 지정하는 지원이 있습니다. 전지. 설정Datestyle매개 변수 tomdy매일 연도를 선택합니다 해석,dmy선택합니다 주간 해석 또는YMD연말 해석을 선택하려면
postgresql더 유연합니다 처리 날짜/배트맨 토토 입력에서SQL표준 요구 사항. 보다부록 B정확한 구문 분석 날짜/배트맨 토토 입력 규칙 및 인식 된 텍스트 필드 달, 요일 및 배트맨 토토대를 포함하여.
날짜 또는 배트맨 토토 문자 그대로 입력이 필요하다는 것을 기억하십시오. 텍스트 문자열과 같은 단일 따옴표로 둘러싸여 있습니다. 참조섹션 4.1.2.5자세한 내용은SQL다음 구문이 필요합니다
타입[(P)] 'value'
어디P선택 사항 정밀 사양은 그에 해당하는 정수입니다 초 분야의 분수 숫자 수. 정밀도 에 대해 지정Time, 타임 스탬프및간격유형. 허용 값은 위에서 언급되어 있습니다. 정밀도가 없다면 일정한 사양으로 지정되며 기본값은 문자 적 가치의 정밀도.
테이블 8-10에 대한 가능한 입력을 보여줍니다날짜타입.
표 8-10. 날짜 입력
example | 설명 |
---|---|
1999 년 1 월 8 일 | Datestyle입력 모드 |
1999-01-08 | ISO 8601; 1 월 8 일 모든 모드에서 (권장 체재) |
1/8/1999 | 1 월 8 일mdy모드; 8 월 1 일dmy모드 |
1/18/1999 | 1 월 18 일mdy모드; 다른 모드에서 거부 |
01/02/03 | 2003 년 1 월 2 일 inmdy모드; 2003 년 2 월 1 일 indmy모드; 2001 년 2 월 3 일 inYMD모드 |
1999-Jan-08 | 1 월 8 일 모든 모드 |
1 월 -08-1999 | 모든 모드에서 1 월 8 일 |
08-Jan-1999 | 1 월 8 일 모든 모드 |
99-Jan-08 | 1 월 8 일YMD모드, else error |
08-Jan-99 | 1 월 8 일, 오류를 제외하고YMD모드 |
1 월 -08-99 | 1 월 8 일, 오류를 제외하고YMD모드 |
19990108 | ISO 8601; 1999 년 1 월 8 일 모든 모드 |
990108 | ISO 8601; 1999 년 1 월 8 일 모든 모드 |
1999.008 | 연도 및 연도 |
J2451187 | Julian Day |
BC 99 년 1 월 8 일 | 99 학년 일반 시대 전 |
배트맨 토토 유형은입니다.배트맨 토토 [ (P)] 배트맨 토토대없이및배트맨 토토 [(P)] 배트맨 토토대와 함께. 그냥 쓰기Time와 동일합니다배트맨 토토대가없는 배트맨 토토.
이러한 유형에 대한 유효한 입력은 하루의 배트맨 토토으로 구성됩니다. 선택적 배트맨 토토대가 이어집니다. (보다테이블 8-11and테이블 8-12.) 입력에 배트맨 토토대가 지정된 경우배트맨 토토대가없는 배트맨 토토, 그것은 조용합니다 무시.
표 8-11. 배트맨 토토 입력
example | 설명 |
---|---|
04:05:06.789 | ISO 8601 |
04:05:06 | ISO 8601 |
04:05 | ISO 8601 |
040506 | ISO 8601 |
04 : 05 AM | 04:05와 동일; AM은 가치에 영향을 미치지 않습니다 |
04 : 05 PM | 16:05와 동일; 입력 배트맨 토토은 <= 12이어야합니다. |
04:05:06.789-8 | ISO 8601 |
04:05:06-08:00 | ISO 8601 |
04:05-08:00 | ISO 8601 |
040506-08 | ISO 8601 |
04 : 05 : 06 PST | 이름별로 지정된 배트맨 토토대 |
표 8-12. 배트맨 토토대 입력
example | 설명 |
---|---|
PST | 태평양 표준 배트맨 토토 |
-8:00 | ISO-8601 PST의 오프셋 |
-800 | ISO-8601 PST의 오프셋 |
-8 | ISO-8601 PST의 오프셋 |
Zulu | UTC에 대한 군사 약어 |
Z | 짧은 형태의Zulu |
참조PostgreSQL : 문서 : 8.0 : 날짜/토토 결과 지원인정되는 배트맨 토토대 이름 목록의 경우 입력.
타임 스탬프 유형에 대한 유효한 입력은 날짜와 배트맨 토토의 연결, 선택 사항 배트맨 토토대, 선택 사항이 뒤 따릅니다ad또는BC. (또는ad/BC배트맨 토토대 앞에 나타날 수는 있지만이 선호하는 주문이 아닙니다.) 따라서
1999-01-08 04:05:06
and
1999-01-08 04:05:06 -8:00
유효한 값이며ISO8601 표준. 또한 광범위한 형식
1 월 8 일 04:05:06 1999 PST
지원됩니다.
theSQL표준 차별화배트맨 토토이없는 타임 스탬프 존and배트맨 토토대가있는 타임 스탬프a의 리터럴"+"; 또는"-". 따라서, 표준에 따르면
타임 스탬프 '2004-10-19 10:23:54'
is배트맨 토토대가없는 타임 스탬프, 하는 동안
타임 스탬프 '2004-10-19 10 : 23 : 54+02'
is배트맨 토토대가있는 타임 스탬프. PostgreSQL요구함으로써 표준타임 스탬프와 함께 배트맨 토토대리터럴이 명시 적으로 입력됩니다 :
배트맨 토토대가있는 타임 스탬프 '2004-10-19 10 : 23 : 54+02'
문자가 명시 적으로 존재하지 않는 경우배트맨 토토대가있는 타임 스탬프, postgresql 문자의 배트맨 토토대 표시를 조용히 무시합니다. 즉, 결과 날짜/배트맨 토토 값은 입력 값의 날짜/배트맨 토토 필드는 배트맨 토토대.
for배트맨 토토대가있는 타임 스탬프, 내부적으로 저장된 값은 항상 UTC에 있습니다 (Universal 전통적으로 그리니치 Lear Time으로 알려진 조정 된 배트맨 토토,GMT). 입력 값 명시적인 배트맨 토토대가 지정된 상태에서 UTC로 변환됩니다. 해당 배트맨 토토대에 적절한 오프셋. 배트맨 토토대가없는 경우 입력 문자열에 언급 된 다음 시스템에 의해 표시된 배트맨 토토대TIMEZONE매개 변수, 그리고에 대한 오프셋을 사용하여 UTC로 변환됩니다.TIMEZONEZone.
언제배트맨 토토대가있는 타임 스탬프값은 출력입니다. 항상 UTC에서 현재의TIMEZONE존, 표시 그 지역의 현지 배트맨 토토으로. 다른 배트맨 토토에 배트맨 토토을보기 위해 Zone, 어느 중 하나 변경TimeZone또는 사용 그만큼배트맨 토토대에서구성 (참조섹션 9.9.3).
타임 스탬프없이 배트맨 토토대and배트맨 토토이 지남에 따라 타임 스탬프 존일반적으로타임 스탬프 배트맨 토토대없이값을 가져 가거나 |TimeZone현지 배트맨 토토. 다른 구역 참조는를 사용하여 변환에 대해 지정할 수 있습니다at Time Zone.
간격값은 함께 작성할 수 있습니다 다음 구문 :
[@]수량 Unit[수량 Unit...] [방향]
여기서 :수량is 번호 (서명 가능);UnitisSecond, Minute, Hour, day, Week, Month, 연도, 10 년, Century, 밀레니엄, 또는이 단위의 약어 또는 복수;방향can beAGO또는 빈. AT 부호 (@)는 선택적 노이즈입니다. 다른 양 유닛은 적절한 부호로 암시 적으로 추가됩니다 회계.
일, 배트맨 토토, 몇 분 및 초의 양이 될 수 있습니다 명시적인 단위 표시없이 지정됩니다. 예를 들어,'1 12:59:10'|'1 일 12 배트맨 토토 59 분 10 초'.
선택적 정밀도P0과 6 사이 여야하며 기본값은 입력 문자.
PostgreSQL지원 편의를위한 몇 가지 특별 날짜/배트맨 토토 입력 값 표시테이블 8-13. 값Infinity및-infinity특별히 대표됩니다 시스템 내부에 동일한 방식으로 표시됩니다. 그러나 다른 사람들은 단순히 표현할 수있는 속기입니다 읽을 때 일반 날짜/배트맨 토토 값으로 변환됩니다. (안에 특정한,now및 관련 문자열 즉시 특정 배트맨 토토 값으로 변환됩니다. 읽기.)이 모든 값은 단일로 작성해야합니다. SQL 명령에서 상수로 사용될 때의 따옴표
표 8-13. 특별 날짜/배트맨 토토 입력
입력 문자열 | 유효한 유형 | 설명 |
---|---|---|
epoch | 날짜, 타임 스탬프 | 1970-01-01 00 : 00 : 00+00 (UNIX 시스템 배트맨 토토 영) |
Infinity | 타임 스탬프 | 다른 모든 타임 스탬프보다 늦게 |
-infinity | 타임 스탬프 | 다른 모든 타임 스탬프보다 일찍 |
now | 날짜, Time, 타임 스탬프 | 현재 트랜잭션의 시작 배트맨 토토 |
오늘 | 날짜, 타임 스탬프 | 오늘 자정 |
내일 | 날짜, 타임 스탬프 | 내일 자정 |
어제 | 날짜, 타임 스탬프 | 어제 자정 |
Allballs | Time | 00 : 00 : 00.00 UTC |
다음SQL-컴파일 가능한 함수도 사용할 수 있습니다 해당 데이터의 현재 배트맨 토토 값을 얻으려면 유형:current_date, current_time, current_timestamp, LocalTime, LocalTimestamp. 후자 4 명은 선택적 정밀 사양. (보다섹션 9.9.4.) 그러나 이것들은 SQL 함수이며아님데이터 입력 문자열.
날짜/배트맨 토토 유형의 출력 형식은 하나로 설정할 수 있습니다. 네 가지 스타일 중 ISO 8601,SQL(Ingres), 전통적인 우편둥이 및 독일어, 명령 사용세트 Datestyle. 기본값은입니다.ISO형식. (그만큼SQL표준에는 ISO를 사용해야합니다 8601 형식. 의 이름"SQL"출력 형식은 역사적 사고입니다.)테이블 8-14각 출력 스타일의 예를 보여줍니다. 의 출력날짜and배트맨 토토유형 물론 날짜 또는 배트맨 토토 부분에 따라 주어진 예.
표 8-14. 날짜/배트맨 토토 출력 스타일
스타일 사양 | 설명 | example |
---|---|---|
ISO | ISO 8601/SQL 표준 | 1997-12-17 07:37:16-08 |
SQL | 전통적인 스타일 | 12/17/1997 07 : 37 : 16.00 PST |
Postgres | 원본 스타일 | wed 12 월 17 일 07:37:16 1997 PST |
독일어 | 지역 스타일 | 17.12.1997 07 : 37 : 16.00 PST |
inSQL및 Postgres 스타일, DMY 필드 주문이 있었다면 월 전 날 나타납니다. 지정, 그렇지 않으면 월이 하루 전에 나타납니다. (보다섹션 8.5.1이 설정이 해석에 미치는 영향 입력 값.)테이블 8-15예를 보여줍니다.
표 8-15. 날짜 명령 규칙
Datestyle설정 | 입력 주문 | 출력 예 |
---|---|---|
SQL, dmy | day/Month/년 | 17/12/1997 15 : 37 : 16.00 CET |
SQL, MDY | Month/day/Year | 12/17/1997 07 : 37 : 16.00 PST |
Postgres, dmy | day/Month/Year | 수요일 17 Dec 07:37:16 1997 PST |
간격출력은 입력처럼 보입니다 와 같은 단위를 제외하고 형식Century또는주는 몇 년으로 변환되었습니다 날과AGO적절한 표시. ISO 모드에서 출력은
[ 수량 Unit[ ... ]] [ days ] [ 배트맨 토토:mings:초 ]
날짜/배트맨 토토 스타일은 사용자가 선택할 수 있습니다.데이터 스타일 설정명령,Datestyle매개 변수
그만큼postgresql.conf구성
파일 또는pgdatestyle환경
서버 또는 클라이언트의 변수. 서식 함수TO_CHAR
(참조섹션 9.8)도 사용할 수 있습니다
날짜/배트맨 토토 출력을 포맷하는보다 유연한 방법으로.
배트맨 토토대 및 배트맨 토토 구역 규칙은 영향을받습니다 지구 기하학뿐만 아니라 정치적 결정. 주변의 배트맨 토토대 세계는 1900 년대에 다소 표준화되었다 특히 임의의 변화가 발생하기 쉽습니다 일광 절약 규칙에 대한 존중.PostgreSQL현재 지원됩니다 일광 절약 규칙은 1902 년에서 2038 년까지 규칙입니다 (전체 범위의 기존 유닉스 시스템에 해당합니다 배트맨 토토). 그 범위를 벗어난 배트맨 토토은"표준 배트맨 토토"선택한 배트맨 토토대의 경우 no 그들이 일년 중 어느 부분에 빠지는 지 중요합니다.
PostgreSQL와 호환SQL일반적인 사용에 대한 표준 정의. 그러나SQL표준에는 홀수 믹스가 있습니다 날짜 및 배트맨 토토 유형 및 기능. 두 가지 명백한 문제 이다:
비록날짜타입은 그렇지 않습니다 관련 배트맨 토토대가 있습니다.Time타입 캔. 현실 세계의 배트맨 토토대 날짜와 관련이없는 한 의미가 거의 없습니다. 오프셋이 연중 달라질 수 있기 때문에 일광 절약 배트맨 토토 경계.
기본 배트맨 토토대는 상수 숫자로 지정됩니다. 에서 상쇄UTC. 그것은 따라서 일광 절약 배트맨 토토에 적응할 수 없습니다 날짜/배트맨 토토 산술을 수행 할 때dst경계.
이러한 어려움을 해결하려면 날짜/배트맨 토토을 사용하는 것이 좋습니다 배트맨 토토대를 사용할 때 날짜와 배트맨 토토을 모두 포함하는 유형. 우리 추천하다not사용 유형배트맨 토토대가있는 배트맨 토토(하지만 지원됩니다PostgreSQL레거시 응용 프로그램 및 준수SQL표준).PostgreSQL현지 배트맨 토토대를 가정합니다 날짜 또는 배트맨 토토 만 포함 된 모든 유형의 경우
모든 배트맨 토토대 인식 날짜와 배트맨 토토은 내부적으로 저장됩니다UTC. 그들은 변환됩니다 에 지정된 영역의 현지 배트맨 토토TimeZone구성 클라이언트에 표시되기 전 매개 변수.
theTimeZone구성 매개 변수를 파일에서 설정할 수 있습니다postgresql.conf또는 다른 것 에 설명 된 표준 방법섹션 16.4. 몇 가지도 있습니다 설정하는 특별한 방법 :
ifTimeZonepostgresql.conf또는 a 우체국 마스터 명령 줄 스위치, 서버는 사용을 시도합니다 의 가치TZ환경 기본 배트맨 토토대로 변수. 만약에TZ정의되지 않았거나 배트맨 토토이 없습니다. 알려진 영역 이름PostgreSQL, 서버는 시도합니다 운영 체제의 기본 배트맨 토토대를 결정하십시오 C 라이브러리 기능의 동작 확인localtime (). 기본 배트맨 토토대는입니다 중 가장 가까운 경기로 선정PostgreSQL의 알려진 배트맨 토토대.
theSQL명령배트맨 토토대 설정배트맨 토토대를 설정합니다 세션을 위해. 이것은의 대체 철자입니다.배트맨 토토대 설정더 많은 SQL-Spec 호환 구문.
thePGTZ환경 변수, if 클라이언트에서 설정하고 사용합니다.libpqa 보낼 응용 프로그램배트맨 토토대 설정연결시 서버.
참조PostgreSQL : 문서 : 8.0 : 날짜/토토 결과 지원사용 가능한 배트맨 토토대 목록.
PostgreSQLJulian을 사용합니다 모든 날짜/배트맨 토토 계산 날짜. 그들은 좋은 것을 가지고 있습니다 날짜를 올바르게 예측/계산하는 속성 기원전 4713 년 이상, 연도의 길이는 365.2425 일이라고 가정합니다.
19 세기 이전의 날짜 규칙 흥미로운 독서이지만 보증하기에 충분히 일관되지 않습니다 날짜/배트맨 토토 핸들러로 코딩.