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

선택

롤 토토

SELECT -- 테이블에서 행을 검색하거나 보기

시놉시스

선택 [ 전체 | 고유 [ ON (표현 [, ...] ) ] ]
    * | 표현[ ASoutput_name] [, ...]
    [ 보낸사람from_item[, ...] ]
    [어디에서조건]
    [ 그룹별표현[, ...] ]
    [ 갖는조건[, ...] ]
    [  노동조합 | 교차 | 제외  [ 모두 ]선택]
    [주문 방법표현[ ASC | 설명 | 사용연산자] [, ...] ]
    [ 제한개수| 모두  ]
    [ 오프셋시작]
    [ 업데이트용 [ OF테이블_롤 토토[, ...] ] ]

어디서from_item다음 중 하나일 수 있습니다:

    [만]테이블_롤 토토[ * ] [ [ AS ]별칭 [ ( column_alias [, ...] ) ] ]
    ( 선택) [ 그대로 ]별칭 [ ( column_alias [, ...] ) ]
    함수_롤 토토 ( [ 인수[, ...] ] ) [ 그대로 ]별칭 [ ( column_alias [, ...] | column_definition [, ...] ) ]
    함수_롤 토토 ( [ 인수[, ...] ] ) AS (column_definition [, ...] )
    from_item[ 자연 ]join_type from_item[ 켜짐join_condition| (를 사용하여join_column [, ...] ) ]

설명

선택하나 또는 더 많은 테이블. 일반적인 처리선택다음과 같습니다:

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

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

  3. 만약에그룹별절은 지정된 경우 출력은 다음과 같은 행 그룹으로 나뉩니다. 하나 이상의 값과 일치합니다. 만약하빙절이 있으면 그룹을 제거합니다. 주어진 조건을 만족하지 않는 것입니다. (참조GROUP BY 절그리고가지고 있는 중 조항아래.)

  4. 실제 출력 행은 다음을 사용하여 계산됩니다.선택선택된 각 항목에 대한 출력 표현식 행. (참조선택 목록아래.)

  5. 연산자 사용유니온, INTERSECT제외, 둘 이상의 출력선택문을 결합하여 단일 결과 집합.유니온연산자는 다음 중 하나 또는 둘 다에 있는 모든 행을 반환합니다. 결과 세트.INTERSECT연산자 두 결과 집합 모두에 엄격하게 포함된 모든 행을 반환합니다.제외연산자는 행을 반환합니다. 첫 번째 결과 세트에는 있지만 두 번째 결과 세트에는 없습니다. 에서 세 가지 경우 모두 중복 행은 다음을 제외하고 제거됩니다.전체지정되었습니다. (참조UNION 조항, INTERSECT 조항EXCEPT 조항아래.)

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

  7. 독특중복 제거 결과의 행입니다.뚜렷이 켜짐지정된 모든 표현식과 일치하는 행을 제거합니다.전체(기본값)은 모두를 반환합니다 중복을 포함한 후보 행. (참조DISTINCT 조항아래.)

  8. 만약한도또는오프셋절이 지정되었습니다.선택문은 다음의 하위 집합만 반환합니다. 결과 행. (참조LIMIT 조항아래.)

  9. 업데이트용절로 인해선택잠금 명령문 동시 업데이트에 대해 선택된 행. (참조업데이트 조항아래.)

당신은 있어야 합니다선택에 대한 권한 값을 읽는 테이블입니다. 의 사용용 업데이트요구됨업데이트권한 음.

매개변수

발신

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

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

테이블_롤 토토

기존 롤 토토(선택적으로 스키마 한정) 테이블 또는 보기. 만일입니다 지정하면 해당 테이블만 스캔됩니다. 만일지정되지 않았습니다. 테이블과 모든 하위 테이블(있는 경우)이 스캔됩니다.*테이블 롤 토토에 다음을 추가할 수 있습니다. 하위 테이블을 스캔해야 함을 나타냅니다. 현재 버전에서는 이것이 기본 동작입니다. (에서 7.1 이전 릴리스,이었음 기본 동작입니다.) 기본 동작은 다음과 같습니다. 변경하여 수정됨sql_inheritance구성 옵션.

별칭

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

선택

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

함수_롤 토토

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

join_type

다음 중 하나

  • [ 내부 ] 가입

  • 왼쪽 [ 외부 ] 조인

  • 오른쪽 [ 외부 ] 가입

  • 전체 [ 외부 ] 조인

  • 교차 조인

다음을 위해내부그리고외부조인 유형, 조인 조건은 다음과 같아야 합니다. 지정됨, 즉 정확히 다음 중 하나임자연, ONjoin_condition, 또는사용 중(join_column [, ...]). 참조 의미는 아래에 있습니다. 에 대한크로스 가입, 이 조항 중 어느 것도 나타날 수 없습니다.

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

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

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

반대로,오른쪽 외부 조인결합된 모든 행과 각 행에 대해 하나의 행을 반환합니다. 일치하지 않는 오른쪽 행( 왼쪽). 이것은 단지 표기상의 편의일 뿐입니다. 그것을 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그룹별롤 토토 롤 토토이 아닌 입력 열 롤 토토으로 해석됩니다. 출력 열 롤 토토입니다.

집계 함수가 사용되는 경우 전체에서 계산됩니다. 각 그룹을 구성하는 모든 행에 대해 별도의 값을 생성합니다. 각 그룹(반면 없이그룹별, 집계는 모든 항목에 걸쳐 계산된 단일 값을 생성합니다. 선택한 행). 언제그룹별이다 현재는 유효하지 않습니다.선택그룹 해제된 참조 표현식 목록 집계 함수 내의 열을 제외한 열입니다. 그룹화되지 않은 항목에 대해 반환할 수 있는 값이 두 개 이상 있습니다. 열.

가지고 있는 중

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

가지고 있는 중조건

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

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

선택목록

선택목록(키 사이 단어선택그리고발신)는 출력을 구성하는 표현식을 지정합니다. 의 행선택성명. 는 표현식은 다음에서 계산된 열을 참조할 수 있으며 일반적으로 참조합니다.발신절. 조항을 사용하여ASoutput_name, 다른 롤 토토은 다음과 같습니다. 출력 열에 대해 지정됩니다. 이 롤 토토은 주로 다음 용도로 사용됩니다. 표시할 열에 레이블을 지정합니다. 참조하는 데에도 사용할 수 있습니다. 열의 값주문 기준그리고그룹별절이지만 에는 없음어디에서또는가지고 있는 중절; 거기에 다음 사항을 작성해야 합니다. 대신 표현을 사용하세요.

표현 대신,*될 수 있습니다 모든 열에 대한 약칭으로 출력 목록에 기록됨 선택한 행 중 또한 다음과 같이 쓸 수도 있습니다.테이블_롤 토토.*다음과 같이 해당 테이블에서 나오는 열에 대한 약칭입니다.

유니온

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

select_statement유니온 [ 전체 ]select_statement

select_statement아무거나선택다음이 없는 문주문 기준, 제한또는업데이트용절. (주문 기준그리고제한할 수 있다 하위 표현식이 포함된 경우 하위 표현식에 첨부됩니다. 괄호. 괄호가 없으면 다음 절이 사용됩니다. 결과에 적용하려면유니온, 오른쪽 입력 표현식이 아닙니다.)

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

결과유니온하지 않습니다 다음을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다.전체중복 제거를 방지합니다. (그러므로유니온 전체보통은 보다 훨씬 빠릅니다.유니온; 사용전체가능하다면.)

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

현재,업데이트용그렇지 않을 수도 있습니다 a에 대해 지정됨유니온결과 또는 a의 입력에 대해유니온.

교차

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

select_statement교차 [ 모두 ]select_statement

select_statement아무거나선택statement without an주문 기준, 제한, 또는업데이트용절.

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

결과교차하지 않습니다 다음을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다. 와 함께전체, 다음을 포함하는 행m왼쪽 테이블에 중복되어 있으며n오른쪽 테이블에 중복됨 최소(로 표시됩니다.m,n)번 결과 집합에 포함됩니다.

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

현재,업데이트용그렇지 않을 수도 있습니다 다음 중 하나에 대해 지정되었습니다.교차결과 또는 임의의 입력에 대한교차.

제외

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

select_statement[ 전체 ] 제외)select_statement

select_statement아무거나선택다음이 없는 문주문 기준, 제한, 또는업데이트용절.

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

결과제외하지 않습니다 다음을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다. 와 함께전체, 다음을 포함하는 행m왼쪽 테이블에 중복되어 있으며n오른쪽 테이블에 중복됨 최대(로 표시됩니다.m-n,0)번 결과 집합에 포함됩니다.

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

현재,업데이트용그렇지 않을 수도 있습니다 다음 중 하나에 대해 지정되었습니다.제외결과 또는 어떤 입력에 대해서도제외.

주문 기준

선택사항주문 기준절에는 이 일반적인 형식은 다음과 같습니다.

주문 기준표현[ ASC | 설명 | 사용연산자 ] [, ...]

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

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

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

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

배급사에서 롤 토토 선택 ORDER BY 코드;

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

만약주문 기준표현식은 결과 열 롤 토토과 입력 모두와 일치하는 간단한 롤 토토 열 롤 토토,주문 기준통역하겠습니다 결과 열 롤 토토으로 사용됩니다. 이는 다음과 반대이다. 그 선택그룹별다음에 만들겠습니다. 같은 상황. 이 불일치는 호환 가능하도록 만들어졌습니다. SQL 표준을 사용합니다.

선택적으로 키워드를 추가할 수 있습니다.ASC(오름차순) 또는설명(내림차순)의 표현식 뒤주문 기준절. 지정하지 않은 경우,ASC기본적으로 가정됩니다. 대안적으로, 특정 순서 연산자 롤 토토은에 지정될 수 있습니다.사용 중절.ASC일반적으로 다음과 같습니다.< 사용 중그리고설명이다 일반적으로 다음과 같습니다.사용 중 . (하지만 사용자 정의 데이터 유형의 작성자는 정확히 무엇을 정의할 수 있습니까? 기본 정렬 순서는 다음과 같을 수 있습니다. 다른 롤 토토을 가진 연산자.)

Null 값은 다른 값보다 높게 정렬됩니다. 다른 곳에서는 단어, 오름차순 정렬 순서, 마지막에 null 값 정렬, 내림차순 정렬을 사용하면 null 값이 시작합니다.

문자열 데이터는 다음에 따라 정렬됩니다. 로케일별 대조 순서는 데이터베이스 클러스터가 초기화되었습니다.

독특

만약독특지정됨, 모두 결과 집합에서 중복 행이 제거됩니다(한 행은 유지됨). 각 중복 그룹에서).전체반대를 지정합니다. 모든 행이 유지됩니다. 그게 바로 기본값.

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

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

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

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

제한

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

한도개수| 모두시작

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

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

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

업데이트용

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

업데이트용 [ OF테이블_롤 토토 [, ...] ]

업데이트용행이 발생합니다. 에 의해 검색됨SELECT에 대한 진술 업데이트하는 것처럼 잠겨 있습니다. 이것은 그들이되는 것을 방지합니다 현재까지 다른 거래에 의해 수정되거나 삭제되었습니다. 거래가 종료됩니다. 즉, 시도하는 다른 거래입니다.업데이트, 삭제또는다음을 선택하세요 업데이트이 행 중 현재 날짜까지 차단됩니다. 거래가 종료됩니다. 또한 만약에업데이트, 삭제또는선택 업데이트용다른 거래에서 이미 잠겼습니다. 선택한 행,선택 대상 업데이트다른 거래가 완료될 때까지 기다립니다. 그런 다음 업데이트된 행(또는 행이 없는 경우)을 잠그고 반환합니다. 행이 삭제되었습니다). 자세한 내용은 다음을 참조하세요.12장.

특정 테이블의 롤 토토이 지정된 경우용 업데이트, 그러면 해당 테이블에서 나오는 행만 잠김; 에 사용된 다른 테이블선택평상시처럼 간단히 읽혀집니다.

업데이트용다음에서는 사용할 수 없습니다 반환된 행을 명확하게 식별할 수 없는 컨텍스트 개별 테이블 행; 예를 들어 다음과 함께 사용할 수 없습니다. 집계.

업데이트용이전에 나타날 수 있음제한호환성을 위해PostgreSQL이전 버전 7.3. 이후에 효과적으로 실행됩니다.한도, 그러나 이것이 권장되는 사항입니다. 쓸 곳이요.

주의

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

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

이후롤백, 행 원래 상태로 돌아가지 않고 효과적으로 잠금이 해제됩니다. 잠겨 있지만 수정되지 않은 사전 저장점 상태입니다. 이 위험은 현재 행이 잠겨 있는 경우 발생합니다. 트랜잭션이 업데이트되거나 삭제되었습니다. 이전 잠금 상태는 잊어버렸습니다. 그런 다음 거래가 롤링되면 원래 잠금 명령 사이의 상태로 돌아가기 이후 변경사항에서는 행이 표시되지 않습니다. 전혀 잠겨 있습니다. This is an implementation deficiency 이는 향후 릴리스에서 해결될 예정입니다.포스트그레SQL.

주의

다음에는 가능합니다.선택둘 다 사용하는 명령제한그리고업데이트용반환 조항 에서 지정한 것보다 적은 수의 행제한. 그 이유는제한행을 여러 개 선택하지만 그런 다음 요청을 차단할 수 있습니다.에 대한 업데이트잠금. 일단선택차단 해제, 쿼리 제한 충족되지 않을 수 있으며 행이 반환되지 않을 수 있습니다.선택.

테이블에 참여하려면영화그리고 테이블배포자:

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

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

SELECT * 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 분배기를 $$로 반환합니다.
    SELECT * FROM 유통업체 어디에서 = $1;
$$ 언어 SQL;

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

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

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

호환성

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

생략발신

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

2+2 선택;

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

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

덜 분명한 용도는 법선을 축약하는 것입니다.선택테이블에서:

배포자를 선택하세요.* WHERE distributions.name = '서쪽';

 그랬어 |   롤 토토
------+------------
 108 | 서쪽으로

이것은 암시적이기 때문에 작동합니다발신다른 부분에서 참조되는 테이블마다 항목이 추가됩니다. 의선택문장이지만 그렇지 않음 에서 언급됨발신.

이것은 편리한 약어이지만 오용되기 쉽습니다. 예를 들어 다음 명령은

유통업체 선택.* 유통업체 d;

아마도 실수일 것입니다. 아마도 사용자가 말한 것 같습니다.

SELECT d.* FROM 유통업체 d;

제약되지 않은 조인이 아닌

유통업체를 선택하세요.* FROM 유통업체 d, 유통업체 유통업체;

그는 실제로 얻을 것입니다. 이런 종류의 감지를 돕기 위해 실수,PostgreSQL경고하겠습니다 암시적인 경우-발신기능이 사용되었습니다 에서선택또한 그 진술 명시적인 내용이 포함되어 있습니다.발신절. 또한 암시적-을 비활성화할 수도 있습니다.발신설정을 통한 기능add_missing_from매개변수를 false로 설정합니다.

AS핵심 단어

SQL 표준에서는 선택적 키워드AS그냥 소음이므로 생략할 수 있습니다. 의미에 영향을 미칩니다.PostgreSQL파서에는 이 키워드가 필요합니다 유형 확장성으로 인해 출력 열의 롤 토토을 바꿀 때 기능이 없으면 모호성을 구문 분석하게 됩니다.AS다음에서는 선택사항입니다.발신그러나 항목은.

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

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

SQL:1999는 약간 다른 정의를 사용합니다. SQL-92와 완전히 상위 호환됩니다. 그러나 대부분의 경우,PostgreSQL해석하겠습니다주문 기준또는그룹 으로SQL:1999와 같은 방식으로 표현됩니다.

비표준 조항

조항구별 ON, 제한오프셋있습니다 SQL 표준에는 정의되어 있지 않습니다.