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

선택

이름

윈 토토 -- 테이블에서 행을 검색하거나 보다

시놉시스

선택 [ 전체 | 고유 [ ON (표현 [, ...] ) ] ]
    * | 표현[ ASoutput_name] [, ...]
    [ 에서from_item[, ...] ]
    [ 어디조건]
    [ 그룹별표현[, ...] ]
    [ 갖는조건[, ...] ]
    [  노동조합 | 교차 | 제외  [ 모두 ]선택]
    [주문 방법표현[ ASC | 설명 | 사용연산자] [ NULLS  첫 번째 | 마지막  ] [, ...] ]
    [ 한계개수| 모두  ]
    [ 오프셋시작]
    [  업데이트 | 공유  [ OF테이블_이름[, ...] ] [ 지금 기다리세요 ] [...] ]

어디from_item윈 토토 중 하나일 수 있습니다:

    [ 오직 ]테이블_이름[ * ] [ [ AS ]별칭 [ ( column_alias [, ...] ) ] ]
    ( 선택) [ 그대로 ]별칭 [ ( column_alias [, ...] ) ]
    함수_이름 ( [ 인수[, ...] ] ) [ 그대로 ]별칭 [ ( column_alias [, ...] | 열_정의 [, ...] ) ]
    함수_이름 ( [ 인수[, ...] ] ) AS (column_definition [, ...] )
    from_item[ 자연 ]join_type from_item[ ONjoin_condition| (를 사용하여join_column [, ...] ) ]

설명

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

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

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

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

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

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

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

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

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

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

당신은 있어야 합니다선택에 대한 권한 값을 읽는 테이블입니다. 의 사용용 업데이트또는공유용요구업데이트권한도 마찬가지입니다.

매개변수

발신

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

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

테이블_이름

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

별칭

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

선택

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

함수_이름

함수 호출이 윈 토토에 나타날 수 있습니다.발신절. (이것은 특히 유용합니다. 결과 세트를 반환하는 함수의 경우, 그러나 모든 함수는 사용할 수 있습니다.) 이는 출력이 생성된 것처럼 작동합니다. 이번 싱글 기간 동안 임시 테이블로 사용됨선택명령. 별칭은 윈 토토을 수행할 수 있습니다. 사용되기도 합니다. 별칭을 쓰면 열 별칭 목록 대체 이름을 제공하기 위해 작성할 수도 있습니다. 이상의 함수 복합 반환 속성 유형. 함수가를 반환하도록 정의된 경우기록데이터 유형, 별칭 또는 핵심 단어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개입니다. 사실이 아닙니다.

선택목록

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

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

유니온

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

윈 토토_statement유니온 [ 전체 ]윈 토토_statement

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

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

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

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

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

교차

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

윈 토토_statement교차 [ 모두 ]윈 토토_statement

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

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

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

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

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

제외

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

윈 토토_statement[ 전체 ] 제외)윈 토토_statement

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

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

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

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

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

주문 기준

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

주문 기준표현[ 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.

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

독특

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

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

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

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

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

제한

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

한도개수| 모두시작

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

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

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

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

업데이트용/용 공유하다

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

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

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

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

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

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

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

특정 테이블의 이름이 지정된 경우용 업데이트또는공유용, 그 윈 토토에만 해당 테이블에서 나오는 행은 잠겨 있습니다. 사용된 다른 테이블 에서선택간단히 윈 토토과 같이 읽혀집니다. 평소. 에이업데이트용또는공유용테이블 목록이 없는 절은 영향을 줍니다. 명령에 사용된 모든 테이블. 만약에용 업데이트또는공유용윈 토토에 적용됨 뷰 또는 하위 쿼리는 뷰 또는 하위 쿼리에 사용된 모든 테이블에 영향을 미칩니다. 하위 쿼리입니다.

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

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

주의

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

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

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

주의

윈 토토에는 가능합니다선택둘 다 사용하는 명령제한그리고업데이트/공유용절 지정된 것보다 적은 수의 행을 반환합니다.제한. 그 이유는제한먼저 적용됩니다. 명령 지정된 수의 행을 선택하지만 그 중 하나 이상에 대한 잠금을 얻으려고 시도하는 것을 차단합니다. 일단선택차단해제, 행이 삭제되거나 업데이트되었을 수 있습니다. 쿼리를 충족하지 않습니다어디에서더 이상 조건이 적용되지 않습니다. 돌아왔습니다.

주의

마찬가지로 a에 대해서도 가능합니다.선택명령 사용주문 기준그리고용 업데이트/공유행을 순서대로 반환합니다. 이것은 왜냐하면주문 기준적용됨 첫 번째. 명령은 결과의 순서를 지정하지만 그 결과는 윈 토토과 같습니다. 하나 이상의 잠금을 얻으려고 시도하는 블록 행. 일단선택차단을 해제하면 정렬된 열 중 하나가 수정되어 순서대로 반환됩니다. 해결 방법은 윈 토토과 같습니다. 수행하다선택 ... 업데이트/공유그리고 나서선택 ... 주문 방법.

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

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 표준과 호환됩니다. 하지만 몇 가지 확장 기능이 있습니다. 그리고 일부 누락된 기능이 있습니다.

생략발신

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

2+2 선택;

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

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

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

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

PostgreSQL이전 릴리스 8.1에서는 이 형식의 쿼리를 허용하고 암시적인 쿼리를 추가합니다. 쿼리 항목발신절 쿼리에서 참조하는 각 테이블. 이것은 더 이상 SQL을 준수하지 않기 때문에 기본 동작 표준이며 많은 사람들이 오류가 발생하기 쉬운 것으로 간주합니다. 을 위한 이 동작에 의존하는 애플리케이션과의 호환성add_missing_from구성 변수를 활성화할 수 있습니다.

AS핵심 단어

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

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

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

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

비표준 조항

조항뚜렷이 켜짐, 제한오프셋은 SQL 표준에는 정의되어 있지 않습니다.