색인 정의는 다음을 지정할 수 있습니다.연산자 롤 토토색인의 각 열에 대해.
색인 생성이름켜짐테이블 (열 opclass [, ...]);
  연산자 롤 토토는 다음에서 사용할 연산자를 식별합니다. 해당 열의 인덱스입니다. 예를 들어 유형에 대한 B-트리 인덱스입니다.int4다음을 사용하겠습니다int4_ops클래스; 이 연산자 롤 토토에는 다음이 포함됩니다. 유형 값에 대한 비교 함수int4. 실제로는 기본 연산자 롤 토토 일반적으로 열의 데이터 유형이면 충분합니다. 의 요점 연산자 롤 토토가 있다는 것은 일부 데이터 유형의 경우 의미 있는 인덱스 동작이 두 개 이상이어야 합니다. 예를 들어, 절대값을 기준으로 복소수 데이터 유형을 정렬하고 싶습니다. 또는 실제 부분으로. 두 개의 연산자를 정의하여 이를 수행할 수 있습니다. 데이터 유형에 맞는 클래스를 선택한 다음 적절한 클래스를 선택합니다. 색인을 만들 때.
또한 내장된 연산자 롤 토토가 있습니다. 기본 것:
연산자 롤 토토text_pattern_ops, varchar_pattern_ops, bpchar_pattern_ops및name_pattern_ops다음에서 B-트리 인덱스를 지원합니다. 유형텍스트, varchar, 문자및이름, 각각. 차이점은 일반적인 연산자 롤 토토는 값을 비교한다는 것입니다 문자에 따르기보다는 문자별로 엄격하게 로케일별 데이터 정렬 규칙. 이로 인해 이러한 연산자는 패턴과 관련된 쿼리에 사용하기에 적합한 클래스 일치하는 표현식(좋아요또는 POSIX 정규식) 서버가 표준을 사용하지 않는 경우"ㄷ"로케일. 예를 들어, 당신은 색인을 생성할 수 있습니다.varchar같은 열 이:
CREATE INDEX test_index ON test_table (col varchar_pattern_ops);
C 로케일을 사용한다면 대신에 기본 연산자 롤 토토를 사용하여 색인을 생성하지만 여전히 패턴 일치 쿼리에 유용합니다. 또한 당신이 다음과 같은 경우 기본 연산자 롤 토토를 사용하여 인덱스를 생성해야 합니다. 일반적인 비교와 관련된 쿼리에서 인덱스를 사용하기를 원합니다. 이러한 쿼리는xxx_pattern_ops연산자 롤 토토. 동일한 열에 여러 개의 인덱스를 생성하는 것이 허용됩니다. 다양한 연산자 롤 토토를 사용합니다.
다음 쿼리는 정의된 모든 연산자 롤 토토를 보여줍니다:
선택 am.amname AS index_method,
       opc.opcname AS opclass_name
    pg_am am, pg_opclass opc에서
    여기서 opc.opcamid = am.oid
    ORDER BY index_method, opclass_name;
  각 항목에 포함된 모든 연산자를 표시하도록 확장될 수 있습니다. 수업:
선택 am.amname AS index_method,
       opc.opcname AS opclass_name,
       opr.oprname AS opclass_operator
    pg_am am, pg_opclass opc, pg_amop amop, pg_operator opr에서
    opc.opcamid = am.oid AND
          amop.amopclaid = opc.oid AND
          amop.amopopr = opr.oid
    ORDER BY index_method, opclass_name, opclass_operator;