이 문서는 지원되지 않는 PostgreSQL 버전에 대한 것입니다.
당신은 토토과 같은 페이지를 보고 싶을 수도 있습니다.postgresql : 문서 : 17 : 토토 핫버전 또는 위에 나열된 다른 지원 버전 중 하나를 선택하세요.

선택

이름

SELECT, TABLE, WITH --토토에서 행 검색 테이블 또는 뷰

시놉시스

[ [ 재귀 ] 사용with_query[, ...] ]
선택 [ 전체 | 고유 [ ON (표현 [, ...] ) ] ]
    * | 표현[ [ AS ]output_name] [, ...]
    [ 에서from_item[, ...] ]
    [ 어디조건]
    [ 그룹별표현[, ...] ]
    [ 갖는조건[, ...] ]
    [ 창문window_nameAS (window_definition) [, ...] ]
    [  노동조합 | 교차 | 제외  [ 전체 | 별개의 ]선택]
    [주문 방법표현[ ASC | 설명 | 사용연산자] [ NULLS  첫 번째 | 마지막  ] [, ...] ]
    [ 한계개수| 모두  ]
    [ 오프셋시작[행 | 행 ] ]
    [  먼저 가져오기 | 토토  [개수]  행 | 행 만 ]
    [  업데이트 | 공유  [ OF테이블_이름[, ...] ] [ 지금 기다리세요 ] [...] ]어디에서from_item토토 중 하나일 수 있습니다.[만 ]테이블_이름[ * ] [ [ AS ]별칭 [ ( column_alias [, ...] ) ] ]
    ( 선택) [ 그대로 ]별칭 [ ( column_alias [, ...] ) ]
    with_query_name[ [ 그대로 ]별칭 [ ( column_alias [, ...] ) ] ]
    함수_이름 ( [ 인수[, ...] ] ) [ 그대로 ]별칭 [ ( column_alias [, ...] | column_definition [, ...] ) ]
    함수_이름 ( [ 인수[, ...] ] ) AS (열_정의 [, ...] )
    from_item[ 자연 ]join_type from_item[ 켜짐join_condition| (를 사용하여join_column [, ...] ) ]

그리고with_query토토과 같습니다:

    with_query_name [ ( 컬럼_이름[, ...] ) ] AS (선택 | 삽입 | 업데이트 | 삭제)

표 [만]테이블_이름 [ * ]

설명

선택0에서 행을 검색하거나 더 많은 테이블. 일반적인 처리선택토토과 같습니다:

  1. 토토의 모든 쿼리함께목록은 토토과 같습니다 계산되었습니다. 이는 효과적으로 임시 테이블 역할을 합니다. 에서 참조할 수 있습니다.발신목록. 에이위드더 많이 참조된 쿼리 한 번 이상발신계산만 됨 한 번. (보다와 함께 절아래.)

  2. 토토의 모든 요소발신목록은 토토과 같습니다 계산되었습니다. (각 요소는발신목록은 실제 또는 가상 테이블입니다.) 두 개 이상의 요소가 에 지정됨발신목록에 있습니다. 교차 결합되었습니다. (보다FROM 절아래.)

  3. 만약에어디절이 지정되었습니다. 조건을 만족하지 않는 모든 행은 제거됩니다. 출력에서. (보다WHERE 절아래.)

  4. 만약에그룹별절은 지정하면 출력은 토토과 같은 행 그룹으로 결합됩니다. 하나 이상의 값과 일치합니다. 만약가지고 있는 중절이 있으면 그룹을 제거합니다. 주어진 조건을 만족하지 않는 것입니다. (보다GROUP BY 절그리고가지고 있는 중 절아래.)

  5. 실제 출력 행은 토토을 사용하여 계산됩니다.선택선택된 각 항목에 대한 출력 표현식 행 또는 행 그룹. (보다선택 목록아래.)

  6. 특정 선택제거 결과에서 행이 중복됩니다.선택 구별 ON모든 항목에서 일치하는 행을 제거합니다. 지정된 표현식.모두 선택(기본값)은 토토을 포함한 모든 후보 행을 반환합니다. 중복. (보다DISTINCT 조항아래.)

  7. 연산자 사용유니온, 교차제외, 둘 이상의 출력선택문을 결합하여 단일 결과 집합. 그만큼유니온연산자는 토토 중 하나 또는 둘 다에 있는 모든 행을 반환합니다. 결과 세트. 그만큼교차연산자 두 결과 집합 모두에 엄격하게 포함된 모든 행을 반환합니다. 그만큼제외연산자는 행을 반환합니다. 첫 번째 결과 세트에는 있지만 두 번째 결과 세트에는 없습니다. ~ 안에 세 가지 경우 모두 중복 행은 토토을 제외하고 제거됩니다.전체지정되었습니다. 시끄러운 단어독특명시적으로 추가할 수 있습니다. 중복 행 제거를 지정합니다. 참고하세요독특여기서는 기본 동작입니다. 그렇지만전체기본값은선택그 자체. (보다UNION 조항, INTERSECT 절EXCEPT 조항아래.)

  8. 만약주문 기준절은 지정하면 반환된 행은 지정된 순서로 정렬됩니다. 주문하다. 만약에주문 기준주어지지 않았습니다. 행은 시스템이 가장 빠른 순서로 반환됩니다. 생산하다. (보다ORDER BY 조항아래.)

  9. 만약제한(또는먼저 가져오기) 또는오프셋절이 지정되었습니다.선택문은 토토의 하위 집합만 반환합니다. 결과 행. (보다LIMIT 조항아래.)

  10. 만약업데이트용또는공유용지정되었습니다.선택문은 선택한 행을 잠급니다. 동시 업데이트에 반대합니다. (보다업데이트용/공유용 절아래.)

당신은 있어야 합니다선택권한 a에 사용된 각 열선택명령. 의 사용업데이트용또는공유용요구업데이트권한도 포함됩니다(각 테이블의 최소 하나의 열에 대해 선택된).

매개변수

WITH

WITH절을 사용하면 토토을 수행할 수 있습니다. 이름으로 참조할 수 있는 하나 이상의 하위 쿼리를 지정합니다. 기본 쿼리에서. 하위 쿼리는 효과적으로 토토과 같이 작동합니다. 기본 기간 동안 임시 테이블 또는 뷰 질문. 각 하위 쿼리는 토토과 같습니다.선택, 삽입, 업데이트또는삭제성명. 데이터 수정문을 작성할 때(삽입, 업데이트또는삭제) in함께, 토토을 포함하는 것이 일반적입니다.돌아오는 중절. 의 출력입니다.돌아오는 중, 아님기본 테이블 읽혀지는 임시 테이블을 형성하는 문 수정 기본 쿼리로. 만약에복귀 중입니다 생략하면 명령문은 계속 실행되지만 아무 것도 생성되지 않습니다. 기본 데이터베이스에서 테이블로 참조할 수 없도록 출력됩니다. 질문.

이름(스키마 한정 없이)을 토토에 대해 지정해야 합니다. 각WITH질의. 선택적으로 토토 목록 열 이름을 지정할 수 있습니다. 이것이 생략되면 열은 이름은 하위 쿼리에서 추론됩니다.

만약반복지정되었습니다. 허용합니다선택참조할 하위 쿼리 이름 자체. 이러한 하위 쿼리는 토토 형식을 가져야 합니다.

non_recursive_term유니온 [ 전체 | 별개의 ]recursive_term

여기서 재귀적 자기 참조는 의 오른쪽유니온. 단 하나 쿼리별로 재귀적 자기 참조가 허용됩니다. 재귀적 데이터 수정 문은 지원되지 않지만 토토을 사용할 수 있습니다. 재귀의 결과선택데이터 수정 문에서 쿼리합니다. 보다섹션 7.8예를 들어.

또 다른 효과반복그렇죠WITH쿼리는 순서를 지정할 필요가 없습니다: a 쿼리는 목록의 뒷부분에 있는 다른 쿼리를 참조할 수 있습니다. (단, 순환 참조나 상호 재귀는 그렇지 않습니다. 구현.) 없음반복, 함께쿼리는 참조만 가능 형제자매WITH이전 쿼리 에서함께목록.

의 핵심 속성위드쿼리는 기본 실행마다 한 번만 평가됩니다. 기본 쿼리가 두 번 이상 참조하는 경우에도 마찬가지입니다. 특히, 데이터 수정 문은 토토과 같이 보장됩니다. 기본 실행 여부에 관계없이 한 번만 실행됩니다. 쿼리는 출력의 전부 또는 일부를 읽습니다.

기본 쿼리 및함께쿼리는 모두 (개념적으로) 동시에 실행됩니다. 이것 에서 데이터 수정 문의 효과를 의미합니다.WITH다른 부분에서는 볼 수 없습니다 쿼리를 읽는 것 외에는돌아오는 중출력. 그러한 데이터 수정이 두 개인 경우 명령문이 동일한 행을 수정하려고 시도하면 결과는 토토과 같습니다. 지정되지 않았습니다.

참조PostgreSQL : 문서 : 9.1 : 토토와 함께 (공통 테이블 표현식)용 추가 정보.

발신

발신절은 토토 중 하나를 지정합니다. 에 대한 추가 소스 테이블선택. 만약에 여러 소스가 지정되면 결과는 데카르트입니다. 모든 소스의 곱(교차 조인)입니다. 하지만 보통 반환을 제한하기 위해 자격 조건이 추가되었습니다. 데카르트 곱의 작은 하위 집합에 대한 행입니다.

발신절은 토토을 포함할 수 있습니다. 토토 요소:

테이블_이름

기존 이름(선택적으로 스키마 한정) 테이블 또는 보기. 만약에이다 테이블 이름 앞에 지정하면 해당 테이블만 스캔했습니다. 만약에아님 지정된 경우 테이블과 모든 하위 테이블(만약 모두)가 스캔됩니다. 선택적으로,*테이블 이름 뒤에 명시적으로 지정할 수 있습니다. 하위 테이블이 포함되어 있음을 나타냅니다.

별칭

대체 이름발신별칭을 포함하는 항목입니다. 별칭 간결하게 표현하거나 모호함을 없애기 위해 사용됩니다. 자체 조인(동일한 테이블이 여러 번 스캔되는 경우) 타임스). 별칭을 제공하면 완전히 숨겨집니다. 테이블이나 함수의 실제 이름 예를 들어 주어진FROM foo AS f, 나머지선택반드시 이것을 참고하세요발신항목f아님foo. 별칭을 쓰면 열 대체 기능을 제공하기 위해 별칭 목록을 작성할 수도 있습니다. 테이블의 하나 이상의 열에 대한 이름입니다.

선택

하위-선택토토에 나타날 수 있습니다. 그만큼발신절. 이는 토토과 같은 역할을 합니다. 출력은 임시 테이블로 생성되었지만 이 싱글의 기간선택명령. 참고 보결-선택토토으로 둘러싸여 있어야 합니다. 괄호 및 별칭반드시제공됩니다. 에이젠 토토 : 문서 : 9.1 : 값명령은 토토과 같을 수도 있습니다. 여기에 사용되었습니다.

with_query_name

A 함께쿼리가 참조되었습니다. 마치 쿼리의 이름이 테이블 이름. (사실,함께쿼리는 동일한 이름의 실제 테이블을 숨깁니다. 기본 쿼리의 목적. 필요한 경우 토토을 수행할 수 있습니다. 동일한 이름의 실제 테이블 참조 테이블 이름을 스키마로 한정합니다.) 별칭은 토토과 같습니다. 테이블과 동일한 방식으로 제공됩니다.

함수_이름

함수 호출이 토토에 나타날 수 있습니다.발신절. (이것은 특히 유용합니다. 결과 세트를 반환하는 함수의 경우, 그러나 모든 함수는 사용할 수 있습니다.) 이는 출력이 생성된 것처럼 작동합니다. 이번 싱글 기간 동안 임시 테이블로 사용됨선택명령. 별칭은 토토을 수행할 수 있습니다. 사용되기도 합니다. 별칭을 쓰면 열 별칭 목록 대체 이름을 제공하기 위해 작성할 수도 있습니다. 이상의 함수 복합 반환 속성 유형. 함수가를 반환하도록 정의된 경우기록데이터 유형, 별칭 또는 핵심 단어AS반드시 존재해야 합니다. 그 뒤에는 형식의 열 정의 목록이 옵니다.( 열_이름 데이터_유형 [, ... ] ). 열 정의 목록은 토토과 같아야 합니다. 에서 반환된 열의 실제 개수 및 유형과 일치합니다. 기능.

join_type

토토 중 하나

  • [ 내부 ] 가입

  • 왼쪽 [ 외부 ] 조인

  • 오른쪽 [ 외부 ] 가입

  • 전체 [ 외부 ] 조인

  • 교차 조인

토토을 위해내부그리고외부조인 유형, 조인 조건은 토토과 같아야 합니다. 지정됨, 즉 정확히 토토 중 하나임자연, 켜짐join_condition, 또는사용 중 (join_column [, ...]). 보다 의미는 아래에 있습니다. 을 위한크로스 가입하다, 이 절은 모두 나타날 수 없습니다.

A 가입절은 두 개를 결합함발신항목. 토토과 같은 경우 괄호를 사용하세요. 중첩 순서를 결정하는 데 필요합니다. 에서 괄호가 없는 경우,가입s 왼쪽에서 오른쪽으로 중첩됩니다. 어쨌든가입쉼표보다 더 단단히 바인딩됩니다. 분리발신항목.

교차 조인그리고내부 조인간단한 데카르트식을 생성합니다. 제품, 두 제품을 나열하여 얻은 것과 동일한 결과 최상위 수준의 항목발신, 그러나 조인 조건(있는 경우)에 의해 제한됩니다.교차 조인토토과 동일함내부 조인 켜짐(TRUE), 즉, 행이 없습니다. 자격으로 제거됩니다. 이러한 조인 유형은 표기상의 편리함, 왜냐하면 그들은 아무것도 하지 않기 때문입니다 일반으로는 할 수 없습니다발신그리고어디.

왼쪽 외부 조인모두 반환 적격 데카르트 곱의 행(즉, 모든 조인 조건을 통과하는 결합된 행) 및 하나 왼쪽 테이블의 각 행 복사본 조인 조건을 통과한 오른쪽 행이 없습니다. 이 왼쪽 행은 전체 너비로 확장됩니다. 오른쪽에 null 값을 삽입하여 테이블을 조인했습니다. 열. 주의할 점은 토토과 같습니다.가입절 자체의 조건을 고려하여 어느 것을 결정할지 결정합니다. 행에 일치 항목이 있습니다. 외부 조건이 적용됩니다. 나중에.

반대로,오른쪽 외부 조인결합된 모든 행과 각 행에 대해 하나의 행을 반환합니다. 일치하지 않는 오른쪽 행( 왼쪽). 이것은 단지 표기상의 편의일 뿐입니다. 그것을 a로 변환할 수 있습니다.왼쪽 외부 가입하다왼쪽 및 오른쪽 입력을 전환하여.

완전 외부 조인모두 반환 조인된 행과 일치하지 않는 각 행에 대해 하나의 행 추가 왼쪽 행(오른쪽에 null로 확장됨), 일치하지 않는 각 오른쪽 행에 대해 한 행(확장됨) 왼쪽에 null이 있음).

켜짐join_condition

join_condition은 유형의 값을 생성하는 표현식부울(a와 유사어디에서절)은 조인은 일치하는 것으로 간주됩니다.

사용 중(join_column [, ...] )

양식의 절사용 중( a, b, ... )는의 약어입니다.켜짐 left_table.a = right_table.a AND left_table.b = right_table.b .... 또한,사용 중각 쌍 중 하나만 의미함 동등한 열이 조인에 포함됩니다. 둘 다 출력되지는 않습니다.

자연

자연a의 약어입니다.사용 중모두를 언급하는 목록 이름이 같은 두 테이블의 열입니다.

어디에서

선택사항어디에서절에는 일반적인 형태

어디에서조건

어디에서조건아무거나 유형의 결과로 평가되는 표현식부울. 이를 만족하지 않는 모든 행 조건이 출력에서 ​​제거됩니다. 행은 토토을 만족합니다. 실제 행 값이 토토과 같을 때 true를 반환하는 경우의 조건 변수 참조로 대체됩니다.

그룹별

선택사항그룹별절에는 일반적인 형태

그룹별표현 [, ...]

그룹별로 응축될 것입니다 단일 행에 대해 동일한 값을 공유하는 선택된 모든 행 그룹화된 표현입니다.표현입력 열 이름이거나 이름 또는 서수일 수 있습니다. 출력 열(선택목록 항목), 또는 입력 열 값으로 구성된 임의의 표현식입니다. ~ 안에 모호한 경우, a그룹별이름 이름이 아닌 입력 열 이름으로 해석됩니다. 출력 열 이름입니다.

집계 함수가 사용되는 경우 전체에서 계산됩니다. 각 그룹을 구성하는 모든 행에 대해 별도의 값을 생성합니다. 각 그룹(반면 없이그룹별, 집계는 모든 항목에 걸쳐 계산된 단일 값을 생성합니다. 선택한 행). 언제그룹별이다 현재는 유효하지 않습니다.선택그룹 해제된 참조 표현식 목록 집계 함수 내 또는 그룹화되지 않은 경우를 제외한 열 열은 기능적으로 그룹화된 열에 종속됩니다. 그렇지 않으면 반환할 수 있는 값이 두 개 이상 있을 것입니다. 그룹화되지 않은 열의 경우. 토토과 같은 경우 기능적 종속성이 존재합니다. 그룹화된 열(또는 그 하위 집합)은 기본 키입니다. 그룹화되지 않은 열이 포함된 테이블입니다.

가지고 있는

선택사항가지고 있는 중절에는 일반적인 형태

가지고 있는 중조건

어디에서조건동일합니다 토토에 지정된 대로어디에서절.

가지고 있는 중토토과 같은 그룹 행을 제거합니다. 조건을 만족하지 않습니다.가지고 있는 중토토과 다릅니다어디에서: 어디에서토토 앞의 개별 행을 필터링합니다. 적용그룹별, 동안가지고 있는 중토토에 의해 생성된 그룹 행을 필터링합니다.그룹별. 에서 참조된 각 열조건명확하게 해야 합니다. 참조가 나타나지 않는 한 그룹화 열을 참조합니다. 집계 함수 내에서.

의 존재가지고 있는 중회전 없는 경우에도 그룹화된 쿼리로 쿼리그룹별절. 이거랑 똑같은데 쿼리에 집계 함수가 포함되어 있지만 포함되지 않은 경우 발생합니다.그룹별절. 선택한 모든 행 단일 그룹을 형성하는 것으로 간주되며,선택목록 및가지고 있는 중절은 집계 내에서만 테이블 열을 참조할 수 있습니다. 기능. 이러한 쿼리는 토토과 같은 경우 단일 행을 생성합니다.가지고 있는 중조건이 true이면 행이 0개입니다. 사실이 아닙니다.

선택사항절에는 일반적인 형태

window_nameAS (window_definition ) [, ...]

어디에서window_name이름입니다 토토에서 참조할 수 있습니다.이상절 또는 후속 창 정의 및window_definitionis

[ existing_window_name]
[ 파티션 기준표현[, ...] ]
[주문 방법표현[ ASC | 설명 | 사용연산자] [ NULLS  첫 번째 | 마지막  ] [, ...] ]
[frame_clause ]

만일existing_window_name이 지정되면 토토 항목의 이전 항목을 참조해야 합니다.목록; 새 창은 그 내용을 복사합니다 해당 항목의 분할 절 및 순서 조항이 있는 경우. 이 경우 새 창에서는 해당 창을 지정할 수 없습니다. 소유하다파티션 기준절이며, 지정하다주문 기준복사된 경우에만 창에는 하나도 없습니다. 새 창은 항상 자체 창을 사용합니다. 프레임 조항; 복사된 창은 프레임을 지정하면 안 됩니다. 절.

의 요소파티션 기준목록은 a의 요소와 거의 동일한 방식으로 해석됩니다.그룹별 절, 단, 항상 간단한 표현이고 출력 열의 이름이나 번호는 절대 아닙니다. 또 다른 차이점은 이러한 표현식에는 집계가 포함될 수 있다는 것입니다. 일반에서는 허용되지 않는 함수 호출그룹별절. 여기서는 허용됩니다. 그룹화 및 집계 후에 윈도잉이 발생합니다.

마찬가지로, 의 요소는주문 에 의해목록은 토토과 거의 같은 방식으로 해석됩니다. 의 요소ORDER BY 조항, 그 외에는 표현식은 항상 간단한 표현식으로 간주됩니다. 출력 열의 이름이나 번호는 절대 아닙니다.

선택사항프레임_절토토을 정의합니다창틀창용 프레임에 의존하는 기능(모두가 그렇지는 않음). 창문 프레임은 쿼리의 각 행에 대한 관련 행 집합입니다. (이라고 함현재 행). 그만큼frame_clause토토 중 하나일 수 있음

범위 | 행프레임_시작범위 | 행  사이프레임_시작그리고frame_end

어디에서프레임_시작그리고frame_end토토 중 하나일 수 있음

무제한 선행이전
현재 행팔로잉
무한한 팔로잉

만약frame_end생략되었습니다 기본값은현재 행. 제한 그거요?프레임_시작될 수 없습니다제한 없는 팔로우, frame_end될 수 없습니다무제한 선행frame_end선택사항은 토토에서 더 일찍 나타날 수 없습니다. 위의 목록보다frame_start선택 — 예를 들어현재 행과 사이의 범위이전허용되지 않습니다.

기본 프레이밍 옵션은범위 무한한 선행, 이는와 동일합니다.제한되지 않은 선행 및 현재 사이의 범위 열; 프레임을 파티션의 모든 행으로 설정합니다. 현재 행의 마지막 피어를 통해 시작합니다.주문 기준순서(있는 경우 모든 행을 의미함) 아니오주문 기준). 일반적으로,무제한 선행즉, 프레임은 파티션의 첫 번째 행에서 시작하며 마찬가지로제한 없는 팔로우즉, 프레임은 파티션의 마지막 행으로 끝납니다(상관없이범위또는모드). 안에모드,현재 행프레임이 시작되거나 종료됨을 의미합니다. 현재 행으로; 하지만범위모드는 프레임이 현재로 시작하거나 끝나는 것을 의미합니다. 행의 첫 번째 또는 마지막 피어주문 에 의해주문. 그만큼 이전그리고 토토케이스는 현재 토토에서만 허용됩니다.모드. 프레임이 시작됨을 나타냅니다. 또는 현재 행 앞이나 뒤의 많은 행으로 끝납니다. 열.정수여야 합니다. 변수를 포함하지 않는 표현식, 집계 함수, 또는 창 기능. 값은 null 또는 음수일 수 없습니다. 그러나 현재 행 자체를 선택하는 0일 수 있습니다.

조심하세요옵션은 토토과 같은 경우 예측할 수 없는 결과가 발생합니다.주문 에 의해ordering은 행을 고유하게 정렬하지 않습니다. 그만큼범위옵션은 토토을 보장하도록 설계되었습니다. 의 피어인 행은주문 에 의해주문은 동일하게 취급됩니다. 두 개의 피어 행은 토토과 같습니다. 둘 다 프레임 안에 있거나 둘 다 프레임 안에 있지 않습니다.

a의 목적절은 동작을 지정하기 위해창 기능검색어에 나타남선택 목록또는ORDER BY 조항. 이 함수는 토토을 참조할 수 있습니다.항목을 이름으로 절이상절. 에이절 항목은 토토과 같을 필요는 없습니다. 그러나 어디에서나 참조됩니다. 쿼리에 사용되지 않은 경우 단순히 무시됩니다. 윈도우 기능을 사용할 수 있습니다. 아무 것도 없이절 전혀, 창 함수 호출은 창 정의를 지정할 수 있기 때문에 직접적으로이상절. 하지만, 그만큼절은 토토과 같은 경우 입력을 저장합니다. 둘 이상의 창에 동일한 창 정의가 필요합니다. 기능.

창 기능은 토토에 자세히 설명되어 있습니다.섹션 3.5, 섹션 4.2.8섹션 7.2.4.

선택목록

선택목록(키 사이 단어선택그리고발신)은 출력을 구성하는 표현식을 지정합니다. 의 행선택성명. 그만큼 표현식은 토토에서 계산된 열을 참조할 수 있으며 일반적으로 참조합니다. 그만큼발신절.

테이블에서와 마찬가지로 a의 모든 출력 열은선택이름이 있습니다. 간단히 말해서선택이 이름은 단지 라벨을 지정하는 데 사용됩니다. 표시할 열이지만,선택은 더 큰 쿼리의 하위 쿼리입니다. 이름은 더 큰 쿼리에서 열 이름으로 표시됩니다. 하위 쿼리에 의해 생성된 가상 테이블입니다. 이름을 지정하려면 출력 열에 사용하고 쓰기AS output_name열의 토토 표현. (생략하셔도 됩니다.AS, 하지만 원하는 출력 이름이 일치하지 않는 경우PostgreSQL키워드(참조부록 C). 보호를 위해 향후 키워드 추가에 대비하여 권장됩니다. 당신이 항상 쓰는 것 중 하나입니다AS또는 출력 이름을 큰따옴표로 묶으십시오.) 열을 지정하지 않는 경우 이름, 이름은 자동으로 선택됩니다.포스트그레SQL. 열의 표현식이 토토과 같은 경우 간단한 열 참조인 경우 선택한 이름은 토토과 같습니다. 해당 열의 이름; 더 복잡한 경우에는 생성된 이름 처럼 보이는?열N?보통 선택됩니다.

출력 열의 이름은 열의 내용을 참조하는 데 사용될 수 있습니다. 가치가 있는주문 기준그리고그룹별절이지만 해당 항목에는 없음어디에서또는가지고 있는 중절; 대신에 표현식을 작성해야 합니다.

표현 대신,*될 수 있습니다 모든 열에 대한 약칭으로 출력 목록에 기록됨 선택한 행 중 또한 토토과 같이 쓸 수도 있습니다.테이블_이름.*으로 해당 테이블에서 나오는 열에 대한 약칭입니다. ~ 안에 이러한 경우에는 새 이름을 지정할 수 없습니다.AS; 출력 열 이름은 토토과 같습니다. 테이블 열 이름과 동일합니다.

독특

만약특정 선택지정되었습니다. 모든 중복 행은 결과 집합에서 제거됩니다(한 행은 각 중복 그룹에서 보관됨).선택 모두반대를 지정합니다. 모든 행이 유지됩니다. 그게 바로 기본.

선택할 구별 항목: (표현 [, ...] )만 유지합니다 주어진 표현식이 있는 각 행 집합의 첫 번째 행 같다고 평가합니다. 그만큼구별 ON표현식은 와 동일한 규칙을 사용하여 해석됩니다.주문 기준(위 참조). 참고하세요"첫 번째 행"47357_47400주문 기준사용됨 원하는 행이 먼저 나타나도록 합니다. 예를 들어:

토토 DISTINCT ON (위치) 위치, 시간, 보고서
    날씨 보고서에서
    ORDER BY 위치, 시간 DESC;

각 위치에 대한 최신 일기 예보를 검색합니다. 그러나 우리가 사용하지 않았다면주문 기준에 각 위치에 대한 시간 값의 내림차순을 강제로 적용합니다. 각각 예측할 수 없는 시기에 보고를 받았습니다 위치.

구별 ON표현식은 토토과 같아야 합니다. 가장 왼쪽과 일치주문 기준식. 그만큼주문 기준절 일반적으로 토토을 결정하는 추가 표현식이 포함됩니다. 각 행의 원하는 우선순위구별 ON그룹.

유니온

유니온절에는 토토과 같은 일반 사항이 있습니다. 형태:

토토_statement유니온 [ 전체 | 별개의 ]토토_statement

토토_statement아무거나선택토토이 없는 문주문 기준, 제한, 업데이트용또는용 공유하다절. (주문 기준그리고한도에 첨부할 수 있습니다. 하위 표현식이 괄호로 묶인 경우. 없이 괄호 안에는 이 절이 결과에 적용됩니다. 의유니온, 오른쪽이 아님 입력 표현식.)

유니온연산자는 집합을 계산합니다 관련 항목이 반환한 행의 합집합선택문장. 행은 집합 합집합에 있습니다. 결과 중 하나 이상에 나타나는 경우 두 개의 결과 세트 세트. 둘이서선택토토 진술 의 직접 피연산자를 나타냅니다.유니온동일한 수의 열을 생성해야 합니다. 해당 열은 호환 가능한 데이터 유형이어야 합니다.

결과유니온하지 않습니다 토토을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다.전체중복 제거를 방지합니다. (그러므로,UNION ALL보통은 보다 훨씬 빠릅니다.유니온; 사용전체가능하다면.)독특명시적으로 지정하도록 작성할 수 있습니다. 중복 행을 제거하는 기본 동작입니다.

다중유니온연산자 같은선택문이 평가되었습니다. 괄호로 달리 표시하지 않는 한 왼쪽에서 오른쪽으로.

현재,업데이트용그리고공유용둘 중 하나도 지정할 수 없습니다. 에 대한유니온결과 또는 토토 입력에 대해 에이유니온.

교차

교차절에 이 내용이 있습니다 일반 형식:

토토_statement교차 [ 전체 | 별개의 ]토토_statement

토토_statement아무거나선택토토이 없는 문주문 기준, 제한, 업데이트용또는에 대한 공유하다절.

교차연산자는 토토을 계산합니다. 관련 항목이 반환한 행의 교차점을 설정합니다.선택문장. 행은 두 결과 세트 모두에 나타나는 경우 두 결과 세트의 교차점 세트.

결과교차하지 않습니다 토토을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다. 와 함께전체, 토토을 포함하는 행m왼쪽 테이블에 중복되어 있으며n오른쪽 테이블에 중복됨 최소(로 표시됩니다.m,n)번 결과 집합에 포함됩니다.독특명시적으로 지정하도록 작성할 수 있습니다. 중복 행을 제거하는 기본 동작입니다.

다중교차연산자 같은선택문이 평가되었습니다 괄호로 다르게 지정하지 않는 한 왼쪽에서 오른쪽으로.교차토토보다 더 단단히 바인딩됨유니온. 즉,A UNION B 교차 C토토과 같이 읽혀집니다연합(B 교차 C).

현재,업데이트용그리고공유용둘 중 하나도 지정할 수 없습니다 한 동안교차결과 또는 기타 의 입력교차.

제외

제외절에는 토토과 같은 일반 사항이 있습니다. 형태:

토토_statement제외 [ 전체 | 별개의 ]토토_statement

토토_statement아무거나선택토토이 없는 문주문 기준, 제한, 업데이트용또는용 공유하다절.

제외연산자는 토토을 계산합니다. 왼쪽의 결과에 있는 행 집합선택문은 있지만 결과에는 없습니다. 맞아요.

결과제외하지 않습니다 토토을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다. 와 함께전체, 토토을 포함하는 행m왼쪽 테이블에 중복되어 있으며n오른쪽 테이블에 중복됨 최대(로 표시됩니다.m-n,0)번 결과 집합에 포함됩니다.독특명시적으로 지정하도록 작성할 수 있습니다. 중복 행을 제거하는 기본 동작입니다.

다중제외연산자 같은선택문이 평가되었습니다 괄호로 다르게 지정하지 않는 한 왼쪽에서 오른쪽으로.제외토토과 같은 수준에 바인딩유니온.

현재,업데이트용그리고공유용둘 중 하나도 지정할 수 없습니다 한 동안제외결과 또는 모든 입력 의제외.

주문 기준

선택사항주문 방법절에는 이 일반적인 형식은 토토과 같습니다.

주문 기준표현[ ASC | 설명 | 사용연산자] [ NULLS  첫 번째 | 마지막  ] [, ...]

주문 기준절로 인해 지정된 기준에 따라 정렬할 결과 행 표현. 가장 왼쪽에 따라 두 행이 동일한 경우 표현식은 토토 표현식에 따라 비교됩니다. 등. 지정된 모든 항목에 따라 동일한 경우 표현식은 구현에 따라 반환됩니다. 주문하다.

각각표현될 수 있습니다 출력 열의 이름 또는 서수(선택목록 항목) 또는 임의의 항목일 수 있습니다. 입력 열 값으로 구성된 표현식입니다.

서수는 서수를 나타냅니다(왼쪽에서 오른쪽으로) 출력 열의 위치. 이 기능을 사용하면 가능합니다 그렇지 않은 열을 기준으로 순서를 정의하려면 독특한 이름을 가지고 있습니다. 이는 절대 필요하지 않습니다. 왜냐하면 출력 열에 이름을 할당하는 것은 항상 가능합니다 를 사용하여AS절.

토토에서 임의의 표현을 사용하는 것도 가능합니다.주문 기준절, 열 포함 에 나타나지 않는 것선택출력 목록. 따라서 토토 진술은 유효합니다.

배포자에서 이름 선택 ORDER BY 코드;

이 기능의 제한사항은 토토과 같습니다.주문 기준a의 결과에 적용되는 절유니온, 교차또는제외절은 출력 열 이름이나 번호만 지정할 수 있으며 표현.

만일주문 기준표현식은 출력 열 이름과 모두 일치하는 간단한 이름 입력 열 이름,주문 기준할 것이다 이를 출력 열 이름으로 해석합니다. 이것은 반대이다 그 선택은그룹별만들 것이다 같은 상황. 이 불일치는 호환 가능하도록 만들어졌습니다. SQL 표준을 사용합니다.

선택적으로 키워드를 추가할 수 있습니다.ASC(오름차순) 또는설명(내림차순)의 표현식 뒤주문 기준절. 지정하지 않은 경우,ASC기본적으로 가정됩니다. 대안적으로, 특정 순서 연산자 이름은에 지정할 수 있습니다.사용 중절. 주문 연산자 일부 B-트리의 멤버보다 작거나 커야 합니다. 연산자 계열.ASC보통은 에 해당함< 사용 중그리고설명일반적으로 토토과 같습니다.사용 중 . (하지만 제작자는 사용자 정의 데이터 유형은 기본 정렬이 무엇인지 정확하게 정의할 수 있습니다. 순서는 다른 연산자와 일치할 수 있습니다. 이름.)

만약NULL이 마지막임지정됨, null 값은 null이 아닌 모든 값 토토에 정렬됩니다. 만약에NULL이 먼저임이 지정되었습니다. null 값 정렬 null이 아닌 모든 값 앞에. 둘 다 지정되지 않은 경우, 기본 동작은NULL이 마지막임언제ASC지정되거나 암시되며,NULL이 먼저임언제설명이 지정되었습니다(따라서 기본값은 마치 널이 널이 아닌 것보다 큰 것처럼). 언제사용 중이 지정되었습니다. 기본 null 순서는 연산자가 보다 작거나 보다 큰지 여부에 따라 달라집니다. 연산자.

순서 옵션은 해당 표현식에만 적용됩니다. 따르다; 예를 들어x, y 설명으로 주문토토과 같은 의미는 아닙니다x별로 주문하세요 DESC, Y DESC.

문자열 데이터는 데이터 정렬에 따라 정렬됩니다. 이는 정렬 중인 열에 적용됩니다. 이는 재정의될 수 있습니다. 필요에 따라 a를 포함하여콜레이트절 에서표현, 예를 들어주문 BY mycolumn COLLATE "en_US". 을 위한 자세한 내용은 참조섹션 4.2.10그리고PostgreSQL : 문서 : 9.1 : 젠 토토 Support.

제한

제한절은 두 개로 구성됩니다. 독립적인 하위 조항:

한도개수| 모두시작

개수최대값을 지정합니다. 반환할 행 수, 반면시작행 수를 지정합니다. 행 반환을 시작하기 전에 건너뜁니다. 둘 다 지정되면,시작이전 행을 건너뜁니다. 세기 시작함개수반환될 행.

만약에개수표현 NULL로 평가되면 토토과 같이 처리됩니다.한도 모두, 즉 제한이 없습니다. 만약에시작NULL로 평가되어 처리됩니다. 와 동일오프셋 0.

SQL:2008에서는 동일한 결과를 얻기 위해 다른 구문을 도입했습니다. 결과는포스트그레SQL또한 지원합니다. 그것은:

오프셋시작행 | 행개수]  행 | 행 만

이 구문에서는 단순 정수를 제외한 모든 것을 쓰려면 에 대해 상수시작또는개수, 작성해야 합니다. 그 주위에 괄호가 있습니다. 만약에개수a에서 생략됨가져오기절, 그것은 기본값은 1입니다.그리고또한첫 번째그리고토토소리나는 단어는 그렇지 않습니다. 이 조항의 효과에 영향을 미칩니다. 에 따르면 표준,오프셋절이 와야 합니다 이전에가져오기둘 다인 경우 절 현재의; 하지만포스트그레SQL이다 더 편안하고 두 가지 주문 중 하나를 허용합니다.

사용 시제한좋은 생각이네요 사용하려면주문 기준절 결과 행을 고유한 순서로 제한합니다. 그렇지 않으면 당신은 쿼리 행의 예측할 수 없는 하위 집합을 얻게 됩니다. 10번째부터 20번째 행까지를 요구할 수도 있지만 10번째 행은 20번째부터 어떤 순서로요? 당신은 무엇을 모른다 지정하지 않는 한 주문주문 에 의해.

쿼리 플래너는 토토을 수행합니다.제한들어가다 쿼리 계획을 생성할 때 계정을 생성하므로 따라 다른 계획을 얻습니다(다른 행 순서 생성). 당신이 무엇을 사용하는지에 대해제한그리고오프셋. 따라서 다른 것을 사용하여제한/오프셋쿼리 결과의 다른 하위 집합을 선택하는 값일관되지 않음을 제공합니다 결과예측 가능한 결과 순서를 시행하지 않는 한 와 함께주문 기준. 이것은 버그가 아닙니다. 그것 SQL이 그렇지 않다는 사실의 본질적인 결과입니다. 특정 상황에서 쿼리 결과를 제공하겠다고 약속합니다. 주문하지 않는 한주문 기준토토에 익숙합니다. 주문을 제한합니다.

동일한 반복 실행도 가능합니다.제한다른 반환 쿼리 테이블 행의 하위 집합(가 없는 경우)주문 기준결정적 선택을 강제하기 위해 하위 집합. 다시 말하지만 이것은 버그가 아닙니다. 결과의 결정론은 그러한 경우에는 보장되지 않습니다.

업데이트용/용 공유하다

업데이트용절에 이 내용이 있습니다 형태:

업데이트용 [ OF테이블_이름[, ...] ] [ 지금 기다리세요 ]

밀접한 관련공유용절의 형식은 토토과 같습니다.

공유용 [ OF테이블_이름[, ...] ] [ 지금 기다리세요 ]

업데이트용행이 발생합니다. 에 의해 검색됨선택에 대한 진술 업데이트하는 것처럼 잠겨 있습니다. 이것은 그들이되는 것을 방지합니다 현재까지 다른 거래에 의해 수정되거나 삭제되었습니다. 거래가 종료됩니다. 즉, 시도하는 다른 거래입니다.업데이트, 삭제또는선택 대상 업데이트이 행 중 현재 날짜까지 차단됩니다. 거래가 종료됩니다. 또한 만약에업데이트, 삭제또는선택 업데이트용다른 거래에서 이미 잠겼습니다. 선택한 행,선택 업데이트다른 트랜잭션이 완료될 때까지 기다립니다. 그런 토토 업데이트된 행(또는 행이 없는 경우)을 잠그고 반환합니다. 행이 삭제되었습니다). a 이내반복 가능 읽다또는직렬화 가능거래, 그러나 잠길 행에 오류가 발생하면 오류가 발생합니다. 거래가 시작된 이후 변경되었습니다. 추가 논의를 위해 보다스포츠 토토 결과 : 문서 : 9.1 : 동시성 제어.

공유용유사하게 동작하지만, 각각에 대해 배타적 잠금이 아닌 공유 잠금을 획득합니다. 검색된 행. 공유 잠금은 다른 트랜잭션을 차단합니다. 실행할 수 있는업데이트, 삭제또는선택 대상 업데이트이 행에 있지만 이것이 행을 방해하지는 않습니다. 실행할 수 있는공유 선택.

작업이 다른 트랜잭션을 기다리지 않도록 방지하려면 커밋하려면를 사용하세요.NOWAIT옵션. 와 함께NOWAIT, 성명서는 토토을 보고합니다. 선택한 행을 잠글 수 없는 경우 기다리는 대신 오류가 발생합니다. 즉시. 참고하세요지금 대기 중적용 행 수준 잠금에만 — 필수행 공유테이블 수준 잠금이 여전히 사용 중입니다. 일반적인 방법(참조스포츠 토토 결과 : 문서 : 9.1 : 동시성 제어). 당신은 할 수 있습니다 사용PostgreSQL : 문서 : 9.1 : 토토 꽁 머니와 함께NOWAIT옵션을 먼저 획득해야 하는 경우 기다리지 않고 테이블 수준 잠금을 수행합니다.

특정 테이블의 이름이 지정된 경우용 업데이트또는공유용, 그러면 해당 테이블에서 나오는 행은 잠겨 있습니다. 사용된 다른 테이블 에서선택간단히 토토과 같이 읽혀집니다. 평소. 에이업데이트용또는공유용테이블 목록이 없는 절은 영향을 미칩니다. 명령문에 사용된 모든 테이블. 만약에용 업데이트또는공유용토토에 적용됨 뷰 또는 하위 쿼리는 뷰 또는 하위 쿼리에 사용된 모든 테이블에 영향을 미칩니다. 하위 쿼리. 하지만,용 업데이트/공유용토토 대상에 적용되지 않음함께기본이 참조하는 쿼리 질문. a 내에서 행 잠금이 발생하도록 하려면위드질의, 지정용 업데이트또는공유용내부함께질의.

다중업데이트용그리고공유용토토과 같은 경우 절을 작성할 수 있습니다. 서로 다른 잠금 동작을 지정하는 데 필요합니다. 테이블. 동일한 테이블이 언급된 경우(또는 암시적으로 영향을 받은 경우) 둘 다에 의해업데이트용그리고공유용절을 사용하면 토토과 같이 처리됩니다.업데이트용. 마찬가지로 테이블은 토토과 같이 처리됨지금 대기 중그렇다면 이에 영향을 미치는 조항에 명시되어 있습니다.

업데이트용그리고공유용토토과 같은 상황에서는 사용할 수 없습니다. 반환된 행은 개별적으로 명확하게 식별될 수 없습니다. 테이블 행; 예를 들어 토토과 함께 사용할 수 없습니다. 집합.

언제업데이트용또는공유용a의 최상위 수준에 나타납니다.선택쿼리, 잠긴 행 쿼리에 의해 반환된 것과 정확히 일치합니다. 이 경우 조인 쿼리에서 잠긴 행은 토토에 기여하는 행입니다. 조인 행을 반환했습니다. 또한 쿼리를 만족하는 행 쿼리 스냅샷 기준의 조건은 잠기지만 이후에 업데이트된 경우에는 반환되지 않습니다. 스냅샷이 발생하여 더 이상 쿼리 조건을 충족하지 않습니다. 만약에제한을 사용하면 잠금이 한 번 중지됩니다. 제한을 충족할 만큼 충분한 행이 반환되었습니다(그러나 참고 해당 행을 건너뛴 행은오프셋할 것이다 잠긴다). 마찬가지로 만약업데이트용또는공유용커서에서 사용됩니다. 쿼리, 실제로 커서로 가져오거나 지나간 행만 잠깁니다.

언제업데이트용또는공유용하위 항목에 나타남선택, 잠긴 행은 토토으로 반환된 행입니다. 하위 쿼리에 의한 외부 쿼리. 여기에는 더 적은 수의 행이 포함될 수 있습니다. 하위 쿼리만 검사하는 것보다 외부 쿼리의 조건을 사용하여 최적화할 수 있습니다. 하위 쿼리 실행. 예를 들어,

토토 * FROM (토토 * FROM mytable FOR UPDATE) ss WHERE col1 = 5;

행만 잠글 것입니다.col1 = 5, 해당 조건이 텍스트상으로는 하위 쿼리입니다.

주의

행을 잠근 토토 행을 수정하지 마십시오 나중에 저장점 또는PL/pgSQL예외 블록. 에이 후속 롤백으로 인해 잠금이 손실됩니다. 예를 들어:

시작;
토토 * FROM mytable WHERE 키 = 1 FOR UPDATE;
세이브포인트;
UPDATE mytable SET ... WHERE 키 = 1;
s로 롤백;

이후롤백, 행 원래 상태로 돌아가지 않고 효과적으로 잠금이 해제됩니다. 잠겨 있지만 수정되지 않은 사전 저장점 상태입니다. 이 위험은 현재 행이 잠겨 있는 경우 발생합니다. 트랜잭션이 업데이트 또는 삭제되거나 공유 잠금이 있는 경우 독점으로 업그레이드됩니다. 이 모든 경우에 이전 잠금 상태는 잊혀집니다. 거래가 토토과 같은 경우 그런 토토 원래 상태 사이의 상태로 롤백됩니다. 잠금 명령과 후속 변경으로 인해 행은 전혀 잠겨 있지 않은 것 같습니다. 이것은 구현 결함은 토토에서 해결될 것입니다. 향후 릴리스포스트그레SQL.

주의

토토에는 가능합니다선택명령이 토토에서 실행 중입니다.읽기 헌신적인트랜잭션 격리 수준 및 사용주문 방법그리고업데이트/공유용행을 반환하려면 주문하다. 그 이유는주문 에 의해이 먼저 적용됩니다. 명령은 결과를 정렬합니다. 하지만 그런 토토 하나 또는 다른 항목에 대한 잠금을 얻으려는 시도를 차단할 수 있습니다. 더 많은 행. 일단선택차단 해제, 일부 주문 열 값이 수정되었을 수 있습니다. 순서가 잘못된 것처럼 보이는 행(하지만 원래 열 값의 순서대로 표시됩니다. 필요에 따라 이 문제를 해결할 수 있습니다.업데이트/공유용절 예를 들어 하위 쿼리

토토 * FROM (토토 * FROM mytable FOR UPDATE) ss ORDER BY 컬럼1;

이렇게 하면 토토의 모든 행이 잠기게 됩니다.마이테이블반면에업데이트용최상위 수준에서는 잠깁니다. 실제로 반환된 행만. 이것은 토토을 만들 수 있습니다. 상당한 성능 차이가 있습니다. 특히 토토과 같은 경우에 그렇습니다.주문 방법토토과 결합됨제한또는 기타 제한사항. 따라서 이 기술은 동시 발생하는 경우에만 권장됩니다. 순서 열의 업데이트가 예상되며 엄격하게 정렬된 결과가 필요합니다.

그곳에서반복 가능한 읽기또는직렬화 가능거래 격리 수준으로 인해 직렬화가 발생합니다. 실패(와 함께SQLSTATE'40001'), 따라서 없습니다. 이 아래에서 순서가 잘못된 행을 받을 가능성 격리 수준.

명령

명령어

이름

완전히 동일함

토토 * FROM이름

최상위 명령이나 공간 절약형 명령으로 사용할 수 있습니다. 복잡한 쿼리 부분의 구문 변형.

테이블에 참여하려면영화와 함께 테이블배포자:

SELECT f.title, f.did, d.name, f.date_prod, f.kind
    FROM 배급사 d, 영화 f
    여기서 f.did = d.did

       제목 | 그랬어 |     이름 | 날짜_생산 |   친절한
------+------+---------------+------------+----------
 세 번째 남자 | 101 | 영국 라이온 | 1949-12-23 | 드라마
 아프리카 여왕 | 101 | 영국 라이온 | 1951-08-11 | 로맨틱
 ...

열을 합산하려면len모든 영화 중 결과를 토토과 같이 그룹화합니다.종류:

SELECT 종류, 합계(len) AS 전체 FROM 영화 GROUP BY 종류;

   종류 | 총
--------+-------
 액션 | 07:34
 코미디 | 02:58
 드라마 | 14:28
 뮤지컬 | 06:42
 로맨틱 | 04:38

열을 합산하려면len모든 영화 중, 결과를 그룹화합니다.종류그리고 그것을 보여주세요 5시간 미만의 그룹 합계:

SELECT 종류, 합계(len) AS 합계
    영화에서
    종류별로 그룹화
    HAVING sum(len) < 간격 '5시간';

   종류 | 총
--------+-------
 코미디 | 02:58
 로맨틱 | 04:38

토토 두 가지 예는 두 번째 열의 내용에 따른 개별 결과 (이름):

토토 * FROM 유통업체 ORDER BY 이름;
SELECT * 대리점에서 주문 2개;

 그랬어 |       이름
-----+------
 109 | 20세기폭스
 110 | 바이에른 아틀리에
 101 | 영국 사자
 107 | 콜롬비아
 102 | 장 뤽 고다르
 113 | 루소 영화
 104 | 모스필름
 103 | 최고의
 106 | 토호
 105 | 유나이티드 아티스트
 111 | 월트 디즈니
 112 | 워너 브라더스
 108 | 서부 제국

토토 예는 테이블의 합집합을 얻는 방법을 보여줍니다.배포자그리고배우, 결과를 토토으로 제한합니다. 각 표의 문자 W로 시작합니다. 고유한 행만 원했기 때문에 핵심 단어전체이다 생략했습니다.

배포자: 행위자:
 그랬어 |     이름 아이디 |     이름
------+--------------- ----+---
 108 | 서쪽으로 1 | 우디 앨런
 111 | 월트 디즈니 2 | 워렌 비티
 112 | 워너 브라더스 3 | 월터 매튜
 ... ...

SELECT 유통업체.이름
    유통업체로부터
    대리점 이름은 'W%'와 같습니다.
노동 조합
배우 선택.이름
    배우들로부터
    actor.name이 'W%'인 곳;

      이름
----------------
 월트 디즈니
 월터 매튜
 워너 브라더스
 워렌 비티
 서부 제국
 우디 앨런

이 예는 토토에서 함수를 사용하는 방법을 보여줍니다.발신절, 열 포함 및 제외 정의 목록:

CREATE FUNCTION 분배기(int) SETOF 분배기를 $$로 반환합니다.
    토토 * FROM 유통업체 어디에서 = $1;
$$ 언어 SQL;

토토 * FROM 유통업체(111);
 그랬어 |    이름
------+-------------
 111 | 월트 디즈니

CREATE FUNCTION distributions_2(int) SETOF 레코드를 $$로 반환합니다.
    토토 * FROM 유통업체 어디에서 = $1;
$$ 언어 SQL;

토토 * FROM distributions_2(111) AS (f1 int, f2 text);
 f1 |     f2
------+-------------
 111 | 월트 디즈니

이 예는 간단한 사용법을 보여줍니다.함께절:

AS로(
    generate_series(1, 3)에서 x로 무작위()를 선택하세요.
  )
선택 * FROM t
유니온 올
선택 * FROM t

         엑스          
-------
  0.534150459803641
  0.520092216785997
 0.0735620250925422
  0.534150459803641
  0.520092216785997
 0.0735620250925422

토토에 주목하세요.함께쿼리 한 번만 평가되었으므로 동일한 3개로 구성된 두 세트를 얻었습니다. 임의의 값.

이 예에서는 토토을 사용합니다.재귀적 사용에 직원 Mary의 모든 부하 직원(직접 또는 간접)을 찾습니다. 및 간접적인 수준만 보여주는 표를 통해 알 수 있습니다. 직속 부하:

재귀적 직원_recursive(거리, 직원_이름, 관리자_이름) AS (
    SELECT 1, 직원_이름, 관리자_이름
    직원으로부터
    WHERE 관리자 이름 = '메리'
  유니온 올
    SELECT er.distance + 1, e.employee_name, e.manager_name
    FROM Employee_recursive er, 직원 e
    어디에서 er.employee_name = e.manager_name
  )
SELECT 거리, 직원_이름 FROM 직원_재귀;

재귀 쿼리의 일반적인 형태에 주목하세요: 초기 조건 토토에유니온, 팔로우함 쿼리의 재귀 부분에 의해. 재귀적인지 확인하십시오. 쿼리의 일부는 결국 튜플을 반환하지 않습니다. 그렇지 않으면 쿼리는 무한정 반복됩니다. (보다섹션 7.8더 많은 예를 보려면.)

호환성

물론입니다.선택문은 토토과 같습니다 SQL 표준과 호환됩니다. 하지만 몇 가지 확장 기능이 있습니다. 그리고 일부 누락된 기능이 있습니다.

생략발신

포스트그레SQL토토을 허용합니다 생략발신절. 그것은 간단한 결과를 계산하는 데 직접 사용 표현:

2+2 선택;

 ?열?
----------
        4

다른 것SQL데이터베이스 더미 1행 테이블을 도입하는 것 외에는 이 작업을 수행할 수 없습니다. 무엇을 할 것인가선택.

참고: 만약에 a발신절이 아님 지정하면 쿼리는 데이터베이스 테이블을 참조할 수 없습니다. 을 위한 예를 들어 토토 쿼리는 유효하지 않습니다.

유통업체를 선택하세요.* WHERE distributions.name = 'Westward';

포스트그레SQL이전 릴리스 8.1에서는 이 형식의 쿼리를 허용하고 암시적인 쿼리를 추가합니다. 쿼리 항목발신절 쿼리에서 참조하는 각 테이블. 이것은 더 이상 허용된.

생략AS핵심 단어

SQL 표준에서는 선택적 키워드AS출력 열 이름 앞에 생략 가능 새 열 이름이 유효한 열 이름일 때마다(즉, 예약된 키워드와 동일하지 않음).포스트그레SQL약간 더 제한적입니다.AS새 열 이름이 있는 경우 필수입니다. 예약 여부에 관계없이 모든 키워드와 일치합니다. 추천 연습은 사용하는 것입니다AS또는 큰따옴표 충돌 가능성을 방지하기 위해 출력 열 이름 향후 키워드 추가.

발신항목, 둘 다 표준 그리고포스트그레SQL허용AS토토 별칭 앞에는 생략됩니다. 예약되지 않은 키워드입니다. 그러나 이것은 출력에는 비현실적입니다. 구문의 모호함으로 인해 열 이름이 변경되었습니다.

및 상속

SQL 표준에서는 테이블 이름 주위에 괄호가 필요합니다. 글을 쓸 때, 예를 들어토토 * FROM ONLY(tab1), ONLY(tab2) 어디 .... 포스트그레SQL이러한 괄호는 선택사항으로 간주됩니다.

포스트그레SQL허용합니다 후행*명시적으로 작성됨 비-를 지정의 행동 하위 테이블을 포함합니다. 표준에서는 이를 허용하지 않습니다.

(이 포인트는 토토을 지원하는 모든 SQL 명령에 동일하게 적용됩니다. 그만큼옵션.)

사용 가능한 네임스페이스그룹별그리고주문 방법

SQL-92 표준에서는,주문 기준절은 출력 열 이름이나 숫자만 사용할 수 있지만 a그룹별절은 토토만 사용할 수 있습니다. 입력 열 이름을 기반으로 하는 표현식입니다.포스트그레SQL이러한 각 절을 확장합니다. 다른 선택도 허용합니다(그러나 표준의 모호한 경우 해석).PostgreSQL또한 두 절을 모두 허용합니다. 임의의 표현식을 지정합니다. 이름이 표현식은 항상 입력 열 이름으로 간주되지 않고 출력 열 이름.

SQL:1999 이상에서는 약간 다른 정의를 사용합니다. SQL-92와 완전히 상위 호환되지는 않습니다. 대부분의 경우, 하지만,포스트그레SQL할 것이다 해석하다주문 기준또는그룹별같은 방식으로 표현 SQL:1999 하다.

기능적 종속성

포스트그레SQL인식합니다 기능적 종속성(열을 생략할 수 있음)그룹별) 테이블의 기본 테이블인 경우에만 키는에 포함되어 있습니다.그룹별목록. SQL 표준은 토토과 같은 추가 조건을 지정합니다. 인식되었습니다.

절 제한

SQL 표준은 창에 대한 추가 옵션을 제공합니다프레임_절. 포스트그레SQL현재는 토토만 지원합니다. 위에 나열된 옵션입니다.

제한그리고오프셋

조항제한그리고오프셋아르포스트그레SQL특정 구문, 토토에서도 사용됨MySQL. SQL:2008 표준 조항을 도입했습니다.오프셋 ... 가져오기 첫 번째|토토 ...표시된 것과 동일한 기능에 대해 위에서한도 절. 이 구문은 토토에서도 사용됩니다.IBM DB2. (신청서 작성 대상)오라클자주 사용하는 자동 생성과 관련된 해결 방법rownum열, 토토에서는 사용할 수 없습니다. PostgreSQL, 이러한 절의 효과를 구현합니다.)

업데이트용그리고공유용

하지만업데이트용에 나타남 SQL 표준, 표준에서는 옵션으로만 허용합니다.커서 선언. PostgreSQL어떤 경우에도 허용선택쿼리 및 하위 쿼리선택s, 하지만 이것은 확장입니다. 그만큼공유용변종 및NOWAIT옵션은 토토 항목에 나타나지 않습니다. 기준.

데이터 수정 명령문함께

PostgreSQL허용삽입, 업데이트삭제에 토토과 같이 사용됩니다.위드쿼리. 이것은 아니다 SQL 표준에서 발견되었습니다.

비표준 조항

조항뚜렷이 켜짐아님 SQL 표준에 정의되어 있습니다.