[ [ 재귀 ] 사용with_query[, ...] ]
선택 [ 전체 | 고유 [ ON (표현 [, ...] ) ] ]
* | 표현[ [ 그대로 ]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 (column_definition [, ...] )
from_item[ 자연 ]join_type from_item[ 켜짐join_condition| (를 사용하여join_column[, ...] ) ]
그리고with_query다음과 같습니다:with_query_name [ ( 컬럼_이름[, ...] ) ] AS (선택)
표 [만 ]테이블_이름 [ * ] | with_query_name }
선택0에서 행을 검색하거나 더 많은 테이블. 일반적인 처리선택다음과 같습니다:
다음의 모든 쿼리함께목록은 다음과 같습니다 계산되었습니다. 이는 효과적으로 임시 테이블 역할을 합니다. 에서 참조할 수 있습니다.발신목록. 갑위드더 많이 참조된 쿼리 한 번 이상발신계산만 됨 한 번. (참조와 함께 조항아래.)
모든 요소발신목록은 다음과 같습니다 계산되었습니다. (각 요소는발신목록은 실제 또는 가상 테이블입니다.) 두 개 이상의 요소가 에 지정됨발신목록에 스포츠 토토. 교차 결합되었습니다. (참조FROM 절아래.)
만약어디절이 지정되었습니다. 조건을 만족하지 않는 모든 행은 제거됩니다. 출력에서. (참조WHERE 절아래.)
만약에그룹별절은 지정된 경우 출력은 다음과 같은 행 그룹으로 나뉩니다. 하나 이상의 값과 일치합니다. 만약하빙절이 있으면 그룹을 제거합니다. 주어진 조건을 만족하지 않는 것입니다. (참조GROUP BY 절그리고가지고 있는 중 조항아래.)
실제 출력 행은 다음을 사용하여 계산됩니다.선택선택된 각 항목에 대한 출력 표현식 행. (참조선택 목록아래.)
연산자 사용유니온, 교차및제외, 둘 이상의 출력선택문을 결합하여 단일 결과 집합.유니온연산자는 다음 중 하나 또는 둘 다에 있는 모든 행을 반환합니다. 결과 세트.INTERSECT연산자 두 결과 집합 모두에 엄격하게 포함된 모든 행을 반환합니다.제외연산자는 행을 반환합니다. 첫 번째 결과 세트에는 있지만 두 번째 결과 세트에는 없습니다. 에서 세 가지 경우 모두 중복 행은 다음을 제외하고 제거됩니다.전체지정되었습니다. (참조UNION 조항, 교차 조항및EXCEPT 조항아래.)
만약주문 기준절은 지정하면 반환된 행은 지정된 순서로 정렬됩니다. 주문. 만일주문 기준주어지지 않았습니다. 행은 시스템이 가장 빠른 순서로 반환됩니다. 생산하다. (참조ORDER BY 조항아래.)
독특중복 제거 결과의 행입니다.구별 ON지정된 모든 표현식과 일치하는 행을 제거합니다.전체(기본값)은 모두를 반환합니다. 중복을 포함한 후보 행. (참조DISTINCT 조항아래.)
만약에한도(또는다음 [) 또는오프셋절이 지정되었습니다.선택문은 다음의 하위 집합만 반환합니다. 결과 행. (보다LIMIT 조항아래.)
만약업데이트용또는공유용이 지정되었습니다.선택문은 선택한 행을 잠급니다. 동시 업데이트에 반대합니다. (참조업데이트용/공유용 조항아래.)
당신은 있어야 합니다선택권한 a에 사용된 각 열선택명령. 의 사용업데이트용또는공유용요구업데이트권한도 포함됩니다(각 테이블의 최소 하나의 열에 대해 선택됨).
그위드절을 사용하면 다음을 수행할 수 있습니다. 이름으로 참조할 수 있는 하나 이상의 하위 쿼리를 지정합니다. 기본 쿼리에서. 하위 쿼리는 효과적으로 다음과 같이 작동합니다. 기본 기간 동안 임시 테이블 또는 뷰 쿼리.
이름(스키마 한정 없이)을 다음에 대해 지정해야 합니다. 각각함께질의. 선택적으로 다음 목록 열 이름을 지정할 수 있습니다. 이것이 생략되면 열은 이름은 하위 쿼리에서 추론됩니다.
만약반복이 지정되었습니다. 하위 쿼리가 이름으로 자신을 참조할 수 있습니다. 이러한 하위 쿼리 형식이 있어야 합니다.
non_recursive_term유니온 [ 전체 ]recursive_term
여기서 재귀적 자기 참조는 의 오른쪽유니온. 단 하나 쿼리별로 재귀적 자기 참조가 허용됩니다.
또 다른 효과반복그렇군요위드쿼리는 순서를 지정할 필요가 없습니다. 쿼리는 목록의 뒷부분에 있는 다른 쿼리를 참조할 수 스포츠 토토. (단, 순환 참조나 상호 재귀는 그렇지 않습니다. 구현.) 없음반복, WITH쿼리는 참조만 가능 형제자매WITH이전 쿼리 에서위드목록.
유용한 속성WITH쿼리 실행마다 한 번만 평가된다는 것입니다. 기본 쿼리가 기본 쿼리를 더 많이 참조하더라도 한 번 이상.
참조PostgreSQL : 문서 : 8.4 : 토토 사이트 순위와 함께 (공통 테이블 표현식)용 추가 정보.
그발신절은 다음 중 하나를 지정합니다. 에 대한 추가 소스 테이블선택. 만약에 여러 소스가 지정되면 결과는 데카르트입니다. 모든 소스의 곱(교차 조인)입니다. 하지만 보통 반환을 제한하기 위해 자격 조건이 추가되었습니다. 데카르트 곱의 작은 하위 집합에 대한 행입니다.
그발신절은 다음을 포함할 수 있습니다. 다음 요소:
기존 이름(선택적으로 스키마 한정) 테이블 또는 보기. 만일만이다 테이블 이름 앞에 지정하면 해당 테이블만 스캔했습니다. 만일만아님 지정된 경우 테이블과 모든 하위 테이블(만약 모두)가 스캔됩니다. 선택적으로,*테이블 이름 뒤에 명시적으로 지정할 수 있습니다. 하위 테이블이 포함되어 있음을 나타냅니다.
대체 이름발신별칭을 포함하는 항목입니다. 별칭 간결하게 표현하거나 모호함을 없애기 위해 사용됩니다. 자체 조인(동일한 테이블이 여러 번 스캔되는 경우) 번). 별칭을 제공하면 완전히 숨겨집니다. 테이블이나 함수의 실제 이름 예를 들어 주어진FROM foo AS f, 나머지선택반드시 이것을 참고하세요발신다음과 같은 항목f아님foo. 별칭을 쓰면 열 대체 기능을 제공하기 위해 별칭 목록을 작성할 수도 있습니다. 테이블의 하나 이상의 열에 대한 이름입니다.
하위-선택다음에 나타날 수 있습니다.발신절. 이는 다음과 같은 역할을 합니다. 출력은 임시 테이블로 생성되었지만 이 싱글의 기간선택명령. 참고 하위-선택다음으로 둘러싸여야 합니다. 괄호 및 별칭반드시그것을 위해 제공됩니다. 갑토토 43_96명령 여기서도 사용할 수 스포츠 토토.
A WITH쿼리가 참조되었습니다. 마치 쿼리의 이름이 테이블 이름. (사실,함께쿼리는 동일한 이름의 실제 테이블을 숨깁니다. 기본 쿼리의 목적. 필요한 경우 다음을 수행할 수 있습니다. 동일한 이름의 실제 테이블 참조 테이블 이름을 스키마로 한정합니다.) 별칭은 다음과 같습니다. 테이블과 동일한 방식으로 제공됩니다.
함수 호출이 다음에 나타날 수 있습니다.발신절. (이것은 특히 유용합니다. 결과 세트를 반환하는 함수의 경우, 그러나 모든 함수는 사용할 수 스포츠 토토.) 이는 출력이 생성된 것처럼 작동합니다. 이번 싱글 기간 동안 임시 테이블로 사용됨선택명령. 별칭은 다음을 수행할 수 있습니다. 사용되기도 합니다. 별칭을 쓰면 열 별칭 목록 대체 이름을 제공하기 위해 작성할 수도 있습니다. 이상의 함수 복합 반환 속성 유형. 함수가를 반환하도록 정의된 경우기록데이터 유형, 별칭 또는 핵심 단어AS반드시 존재해야 합니다. 그 뒤에는 형식의 열 정의 목록이 옵니다.( 열_이름 데이터_유형 [, ... ] ). 열 정의 목록은 다음과 같아야 합니다. 에서 반환된 열의 실제 개수 및 유형과 일치합니다. 기능.
다음 중 하나
[ 내부 ] 가입
왼쪽 [ 외부 ] 조인
오른쪽 [ 외부 ] 가입
전체 [ 외부 ] 조인
교차 조인
다음을 위해내부그리고외부조인 유형, 조인 조건은 다음과 같아야 합니다. 지정됨, 즉 정확히 다음 중 하나임자연스러운, ONjoin_condition, 또는사용 중(join_column [, ...]). 참조 의미는 아래에 있습니다. 에 대한크로스 가입, 이 절은 모두 나타날 수 없습니다.
A 가입절은 두 개를 결합합니다발신항목. 다음과 같은 경우 괄호를 사용하세요. 중첩 순서를 결정하는 데 필요합니다. 에서 괄호가 없는 경우,가입s 왼쪽에서 오른쪽으로 중첩됩니다. 어쨌든가입쉼표보다 더 단단히 바인딩됩니다. 분리발신항목.
교차 조인그리고내부 조인간단한 데카르트식 생성 제품, 두 제품을 나열하여 얻은 것과 동일한 결과 최상위 수준의 항목발신, 그러나 조인 조건(있는 경우)에 의해 제한됩니다.교차 조인다음과 동일함내부 조인 켜짐(TRUE), 즉, 행이 없습니다. 자격으로 제거됩니다. 이러한 조인 유형은 표기상의 편리함, 왜냐하면 그들은 아무것도 하지 않기 때문입니다 일반으로는 할 수 없습니다발신그리고어디.
왼쪽 외부 조인모두 반환 적격 데카르트 곱의 행(즉, 모든 조인 조건을 통과하는 결합된 행) 및 하나 왼쪽 테이블의 각 행 복사본 조인 조건을 통과한 오른쪽 행이 없습니다. 이 왼쪽 행은 전체 너비로 확장됩니다. 오른쪽에 null 값을 삽입하여 테이블을 조인했습니다. 열. 주의할 점은 다음과 같습니다.가입절 자체의 조건을 고려하여 어느 것을 결정할지 결정합니다. 행에 일치 항목이 있습니다. 외부 조건이 적용됩니다. 나중에요.
반대로,오른쪽 외부 조인결합된 모든 행과 각 행에 대해 하나의 행을 반환합니다. 일치하지 않는 오른쪽 행( 왼쪽). 이것은 단지 표기상의 편의일 뿐입니다. 그것을 a로 변환할 수 스포츠 토토.왼쪽 외부 가입왼쪽 및 오른쪽 입력을 전환하여.
완전 외부 조인모두 반환 조인된 행과 일치하지 않는 각 행에 대해 하나의 행 추가 왼쪽 행(오른쪽에 null로 확장됨), 일치하지 않는 각 오른쪽 행에 대해 한 행(확장됨) 왼쪽에 null이 있음).
join_condition은 유형의 값을 생성하는 표현식부울(a와 유사어디에서절)은 조인은 일치하는 것으로 간주됩니다.
양식의 절사용 중(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정의창틀창용 프레임에 의존하는 기능(모두가 그렇지는 않음). 하나일 수도 있어요 의
범위 제한 없는 선행 경계가 없는 선행 행과 현재 행 사이의 범위 무한한 선행과 무한한 다음 사이의 범위 행의 경계가 없는 선행 경계가 없는 선행 행과 현재 행 사이의 행 경계 없는 선행과 경계 없는 다음 사이의 행
처음 두 개는 동일하며 기본값이기도 합니다. 프레임이 파티션 시작의 모든 행이 되도록 설정합니다. 현재 행의 마지막 피어를 통해주문 기준순서(있는 경우 모든 행을 의미함) 아니오주문 기준). 옵션제한 없는 선행 및 다음 사이의 범위 무한한 팔로잉그리고행 사이 무한한 선행 및 무한한 다음또한 동일: 항상 파티션의 모든 행을 선택합니다. 마지막으로,앞으로 바운드되지 않은 행또는 그것의 장황한 동등물행 사이 무한한 선행 및 현재 행위의 모든 행 선택 현재 행을 통해(중복 여부에 관계없이) 조심하세요 이 옵션은 다음과 같은 경우 구현에 따른 결과를 생성할 수 있습니다.주문 기준주문은 주문하지 않습니다 행은 고유합니다.
a의 목적창절은 동작을 지정하기 위해창 기능쿼리의 항목에 표시됨선택 목록또는ORDER BY 조항. 이 함수는 다음을 참조할 수 있습니다.창항목을 이름으로 절이상절. 갑창절 항목은 다음과 같을 필요는 없습니다. 그러나 어디에서나 참조됩니다. 쿼리에 사용되지 않은 경우 단순히 무시됩니다. 윈도우 기능을 사용할 수 있습니다. 아무 것도 없이창절 전혀, 창 함수 호출은 창 정의를 지정할 수 있기 때문에 직접적으로이상절. 그러나,창절은 다음과 같은 경우 입력을 저장합니다. 둘 이상의 창에 동일한 창 정의가 필요합니다. 기능.
그선택목록(키 사이 단어선택그리고발신)는 출력을 구성하는 표현식을 지정합니다. 의 행선택문장. 는 표현식은 다음에서 계산된 열을 참조할 수 있으며 일반적으로 참조합니다.발신절.
테이블에서와 마찬가지로 a의 모든 출력 열은선택이름이 있습니다. 간단히 말해서선택이 이름은 단지 라벨을 지정하는 데 사용됩니다. 표시할 열이지만,선택은 더 큰 쿼리의 하위 쿼리입니다. 이름은 더 큰 쿼리에서 열 이름으로 표시됩니다. 하위 쿼리에 의해 생성된 가상 테이블입니다. 이름을 지정하려면 출력 열에 사용하고 쓰기AS output_name열의 다음 표현. (생략하셔도 됩니다.AS, 하지만 원하는 출력 이름이 일치하지 않는 경우스포츠 토토키워드(참조부록 C). 보호를 위해 향후 키워드 추가에 대비하여 권장됩니다. 당신이 항상 쓰는 것 중 하나입니다AS또는 출력 이름을 큰따옴표로 묶으십시오.) 열을 지정하지 않는 경우 이름, 이름은 자동으로 선택됩니다.스포츠 토토. 열의 표현식이 다음과 같은 경우 간단한 열 참조인 경우 선택한 이름은 다음과 같습니다. 해당 열의 이름; 더 복잡한 경우에는 생성된 이름 처럼 보이는?열N?보통 선택됩니다.
출력 열의 이름은 열의 내용을 참조하는 데 사용될 수 있습니다. 가치가 있는주문 방법그리고그룹별절이지만 에는 없음어디또는가지고 있는 중절; 대신에 표현식을 작성해야 합니다.
표현식 대신*될 수 있습니다 모든 열에 대한 약칭으로 출력 목록에 기록됨 선택한 행 중 또한 다음과 같이 쓸 수도 있습니다.테이블_이름.*다음과 같이 해당 테이블에서 나오는 열에 대한 약칭입니다. 에서 이러한 경우에는 새 이름을 지정할 수 없습니다.AS; 출력 열 이름은 다음과 같습니다. 테이블 열 이름과 동일합니다.
그유니온절에는 다음과 같은 일반 사항이 있습니다. 형식:
select_statement유니온 [ 전체 ]select_statement
select_statement아무거나선택다음이 없는 문주문 기준, 제한, 업데이트용, 또는용 공유절. (주문 기준그리고제한에 첨부할 수 있습니다. 하위 표현식이 괄호로 묶인 경우. 없이 괄호 안에는 이 절이 결과에 적용됩니다. 의유니온, 오른쪽이 아님 입력 표현식.)
그유니온연산자는 집합을 계산합니다. 관련 항목이 반환한 행의 합집합선택문장. 행은 집합 합집합에 있습니다. 결과 중 하나 이상에 나타나는 경우 두 개의 결과 세트 세트. 둘이서선택그 진술은 의 직접 피연산자를 나타냅니다.유니온동일한 수의 열을 생성해야 합니다. 해당 열은 호환 가능한 데이터 유형이어야 합니다.
결과유니온하지 않습니다 다음을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다.전체중복 제거를 방지합니다. (그러므로유니온 전체보통은 보다 훨씬 빠릅니다.유니온; 사용전체가능하다면.)
다중유니온연산자 같은SELECT문이 평가되었습니다. 괄호로 달리 표시하지 않는 한 왼쪽에서 오른쪽으로.
현재,업데이트용그리고공유용둘 중 하나도 지정할 수 없습니다. 에 대한유니온결과 또는 다음 입력에 대해 에유니온.
그교차절에 이 내용이 스포츠 토토 일반 형식:
select_statement교차 [ 모두 ]select_statement
select_statement아무거나선택다음이 없는 문주문 기준, 제한, 업데이트용또는용 공유절.
그교차연산자는 다음을 계산합니다. 관련 항목이 반환한 행의 교차점을 설정합니다.선택문장. 행은 두 결과 세트 모두에 나타나는 경우 두 결과 세트의 교차점 세트.
결과INTERSECT하지 않습니다 다음을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다. 와 함께전체, 다음을 포함하는 행m왼쪽 테이블에 중복되어 있으며n오른쪽 테이블에 중복됨 최소(로 표시됩니다.m,n45597_45625
다중교차연산자 같은선택문이 평가되었습니다 괄호로 다르게 지정하지 않는 한 왼쪽에서 오른쪽으로.교차다음보다 더 단단히 바인딩됨유니온. 즉,A UNION B 교차 C다음과 같이 읽혀집니다연합(B 교차 C).
현재,업데이트용그리고공유용둘 중 하나도 지정할 수 없습니다 한 동안교차결과 또는 기타 의 입력교차.
그제외절에는 다음과 같은 일반 사항이 있습니다. 형식:
select_statement[ 모두 ] 제외)select_statement
select_statement아무거나선택다음이 없는 문주문 기준, 제한, 업데이트용, 또는용 공유절.
그제외연산자는 다음을 계산합니다. 왼쪽의 결과에 있는 행 집합선택문장이지만 결과에는 없음 맞아요.
결과제외하지 않습니다 다음을 제외하고 중복 행을 포함합니다.전체옵션이 지정되었습니다. 와 함께전체, 다음을 포함하는 행m왼쪽 테이블에 중복되어 있으며n오른쪽 테이블에 중복됨 최대(로 표시됩니다.m-n47611_47641
다중제외연산자 같은선택문이 평가되었습니다 괄호로 다르게 지정하지 않는 한 왼쪽에서 오른쪽으로.제외다음과 같은 수준에 바인딩유니온.
현재,업데이트용그리고공유용둘 중 하나도 지정할 수 없습니다 한 동안제외결과 또는 모든 입력 의제외.
선택사항주문 기준절에는 이 일반적인 형식은 다음과 같습니다.
주문 기준표현[ 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표현식은 과 동일한 규칙을 사용하여 해석됩니다.주문 방법(위 참조). 참고하세요"첫 번째 행"53494_53537주문 기준사용됨 원하는 행이 먼저 나타나도록 합니다. 예를 들면:
SELECT DISTINCT ON (위치) 위치, 시간, 보고서
날씨 보고서에서
ORDER BY 위치, 시간 DESC;
각 위치에 대한 최신 일기 예보를 검색합니다. 그러나 우리가 사용하지 않았다면주문 기준에 각 위치에 대한 시간 값의 내림차순을 강제로 적용합니다. 각각 예측할 수 없는 시기에 보고를 받았습니다 위치.
그구별 ON표현식은 다음과 같아야 합니다. 가장 왼쪽과 일치주문 방법식.주문 방법절 일반적으로 다음을 결정하는 추가 표현식이 포함됩니다. 각 행의 원하는 우선순위뚜렷이 켜짐그룹.
그제한절은 두 개로 구성됩니다. 독립적인 하위 조항:
한도개수| 모두시작
개수최대값을 지정합니다. 반환할 행 수, 반면시작행 수를 지정합니다. 행 반환을 시작하기 전에 건너뜁니다. 둘 다 지정되면,시작이전에 행을 건너뛰었습니다. 세기 시작함개수반환될 행.
만약에개수표현 NULL로 평가되면 다음과 같이 처리됩니다.한도 모두, 즉 제한이 없습니다. 만일시작NULL로 평가되어 처리됩니다. 와 동일오프셋 0.
SQL:2008에서는 동일한 결과를 얻기 위해 다른 구문을 도입했습니다. 스포츠 토토도 지원하는 것입니다. 그것은:
오프셋시작행 | 행개수] 행 | 행 만
두 조항 모두 선택 사항이지만, 존재하는 경우오프셋절은 다음 앞에 와야 합니다.가져오기절.ROW그리고행또한첫 번째그리고다음있습니다 이 조항의 효과에 영향을 주지 않는 의미 없는 단어입니다. 이 구문에서는 단순 표현식 이외의 표현식을 사용하는 경우 에 대한 상수시작또는개수, 괄호는 다음과 같습니다. 대부분의 경우 필요합니다. 만일개수생략됨가져오기, 기본값은 1입니다.
사용 시제한좋은 생각이네요 사용하려면주문 기준절 결과 행을 고유한 순서로 제한합니다. 그렇지 않으면 당신은 쿼리 행의 예측할 수 없는 하위 집합을 얻게 됩니다. 10번째부터 20번째 행까지를 요구할 수도 있지만 10번째 행은 20번째부터 어떤 순서로요? 당신은 무엇을 모른다 지정하지 않는 한 주문주문 으로.
쿼리 플래너는 다음을 수행합니다.제한들어가다 쿼리 계획을 생성할 때 계정을 생성하므로 따라 다른 계획을 얻습니다(다른 행 순서 생성). 당신이 무엇을 사용하는지에 대해제한그리고오프셋. 따라서 다른 것을 사용하여제한/오프셋쿼리 결과의 다른 하위 집합을 선택하는 값일관되지 않은 결과를 제공합니다 결과예측 가능한 결과 순서를 시행하지 않는 한 와 함께주문 기준. 이것은 버그가 아닙니다. 그것 SQL이 그렇지 않다는 사실의 본질적인 결과입니다. 특정 상황에서 쿼리 결과를 제공하겠다고 약속합니다. 주문하지 않는 한주문 기준다음에 익숙합니다. 주문을 제한합니다.
동일한 반복 실행도 가능합니다.제한다른 반환 쿼리 테이블 행의 하위 집합(가 없는 경우)주문 기준결정적 선택을 강제하기 위해 하위 집합. 다시 말하지만 이것은 버그가 아닙니다. 결과의 결정론은 그러한 경우에는 보장되지 않습니다.
그업데이트용절에 이 내용이 스포츠 토토 형식:
업데이트용 [ OF테이블_이름[, ...] ] [ 지금 기다리세요 ]
밀접한 관련공유용절의 형식은 다음과 같습니다.
공유용 [ OF테이블_이름[, ...] ] [ 지금 기다리세요 ]
업데이트용행이 발생합니다. 에 의해 검색됨선택에 대한 진술 업데이트하는 것처럼 잠겨 있습니다. 이것은 그들이되는 것을 방지합니다 현재까지 다른 거래에 의해 수정되거나 삭제되었습니다. 거래가 종료됩니다. 즉, 시도하는 다른 거래입니다.업데이트, 삭제또는선택 업데이트이 행 중 현재 날짜까지 차단됩니다. 거래가 종료됩니다. 또한 만약에업데이트, 삭제, 또는선택 업데이트용다른 거래에서 이미 잠겼습니다. 선택한 행,선택 대상 업데이트다른 거래가 완료될 때까지 기다립니다. 그런 다음 업데이트된 행(또는 행이 없는 경우)을 잠그고 반환합니다. 행이 삭제되었습니다). 자세한 내용은 다음을 참조하세요.13장.
작업이 다른 트랜잭션을 기다리지 않도록 방지하려면 커밋하려면를 사용하세요.지금 대기 중옵션.지금 업데이트를 위해 선택하세요.보고 선택한 행을 잠글 수 없는 경우 기다리는 대신 오류가 발생합니다. 즉시. 참고하세요NOWAIT적용 행 수준 잠금에만 — 필수행 공유테이블 수준 잠금이 여전히 사용 중입니다. 일반적인 방법(참조토토 사이트 순위 : 문서 : 8.4 : 동시성 제어). 당신은 할 수 스포츠 토토 사용하다NOWAIT옵션PostgreSQL : 문서 : 8.4 : 배트맨 토토당신이 획득해야 하는 경우 기다리지 않고 테이블 수준 잠금을 수행합니다.
공유용유사하게 동작하지만, 각각에 대해 배타적 잠금이 아닌 공유 잠금을 획득합니다. 검색된 행. 공유 잠금은 다른 트랜잭션을 차단합니다. 공연 중업데이트, 삭제또는선택 업데이트이 행에 있지만 이를 방해하지는 않습니다. 공연 중공유 선택.
특정 테이블의 이름이 지정된 경우용 업데이트또는공유용, 그러면 해당 테이블에서 나오는 행은 잠겨 스포츠 토토. 사용된 다른 테이블 에서선택간단히 다음과 같이 읽혀집니다. 평소. 갑업데이트용또는공유용테이블 목록이 없는 절은 영향을 미칩니다. 명령에 사용된 모든 테이블. 만일용 업데이트또는공유용다음에 적용됨 뷰 또는 하위 쿼리는 뷰 또는 하위 쿼리에 사용된 모든 테이블에 영향을 미칩니다. 하위 쿼리. 그러나용 업데이트/공유용다음 대상에 적용되지 않음함께기본이 참조하는 쿼리 쿼리. a 내에서 행 잠금이 발생하도록 하려면함께질의, 지정용 업데이트또는공유용내부함께질의.
다중업데이트용그리고공유용다음과 같은 경우 절을 작성할 수 있습니다. 서로 다른 잠금 동작을 지정하는 데 필요합니다. 테이블. 동일한 테이블이 언급된 경우(또는 암시적으로 영향을 받은 경우) 둘 다에 의해업데이트용그리고공유용절을 사용하면 다음과 같이 처리됩니다.업데이트용. 마찬가지로 테이블은 다음과 같이 처리됨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 | 월트 디즈니
이 예는 간단한 사용법을 보여줍니다.함께절:
와 함께 (
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에서는 이 형식의 쿼리를 허용하고 암시적인 쿼리를 추가합니다. 쿼리 항목발신절 쿼리에서 참조하는 각 테이블. 이것은 더 이상 SQL을 준수하지 않기 때문에 기본 동작 표준이며 많은 사람들이 오류가 발생하기 쉬운 것으로 간주합니다. 에 대한 이 동작에 의존하는 애플리케이션과의 호환성add_missing_from구성 변수를 활성화할 수 스포츠 토토.
SQL 표준에서는 선택적 키워드AS출력 열 이름 앞에 생략 가능 새 열 이름이 유효한 열 이름일 때마다(즉, 예약된 키워드와 동일하지 않음).포스트그레SQL약간 더 제한적입니다.AS새 열 이름이 있는 경우 필수입니다. 예약 여부에 관계없이 모든 키워드와 일치합니다. 추천 연습은 사용하는 것입니다AS또는 큰따옴표 충돌 가능성을 방지하기 위해 출력 열 이름 향후 키워드 추가.
에발신항목, 둘 다 표준 그리고스포츠 토토허용AS다음 별칭 앞에는 생략됩니다. 예약되지 않은 키워드입니다. 그러나 이것은 출력에는 비현실적입니다. 구문의 모호함으로 인해 열 이름이 변경되었습니다.
SQL 표준에서는 테이블 이름 주위에 괄호가 필요합니다. 글을 쓸 때만, 예를 들어SELECT * FROM ONLY(tab1), ONLY(tab2) 어디서 .... 포스트그레SQL이러한 괄호는 선택사항으로 간주됩니다.
포스트그레SQL허용합니다 후행*명시적으로 작성됨 비-를 지정만의 행동 하위 테이블을 포함합니다. 표준에서는 이를 허용하지 않습니다.
(이 포인트는 다음을 지원하는 모든 SQL 명령에 동일하게 적용됩니다.만옵션.)
SQL-92 표준에서는,주문 기준절은 출력 열 이름이나 숫자만 사용할 수 있지만 a그룹별절은 다음만 사용할 수 있습니다. 입력 열 이름을 기반으로 하는 표현식입니다.스포츠 토토이러한 각 절을 확장합니다. 다른 선택도 허용합니다(그러나 표준의 모호한 경우 해석).포스트그레SQL또한 두 절을 모두 허용합니다. 임의의 표현식을 지정합니다. 이름이 표현식은 항상 입력 열 이름으로 간주되지 않고 출력 열 이름.
SQL:1999 이상에서는 약간 다른 정의를 사용합니다. SQL-92와 완전히 상위 호환되지는 않습니다. 대부분의 경우, 그러나,포스트그레SQL할 것이다 해석하다주문 방법또는그룹별SQL:1999와 같은 방식으로 표현 그렇습니다.
조항제한그리고오프셋아르포스트그레SQL특정 구문, 다음에서도 사용됨MySQL. SQL:2008 표준 조항을 도입했습니다.오프셋 ... 가져오기 첫 번째|다음 ...표시된 것과 동일한 기능에 대해 위에서한도 조항, 이 구문은 다음에서도 사용됩니다.IBM DB2. (신청서 작성 대상)오라클자주 사용하는 자동 생성과 관련된 해결 방법rownum열, 스포츠 토토에서는 사용할 수 없음 이 조항의 효과를 구현합니다.)