security-admin/db/postgres/patches/074-create-index-for-x_trx_log.sql (21 lines of code) (raw):

-- Licensed to the Apache Software Foundation (ASF) under one or more -- contributor license agreements. See the NOTICE file distributed with -- this work for additional information regarding copyright ownership. -- The ASF licenses this file to You under the Apache License, Version 2.0 -- (the "License"); you may not use this file except in compliance with -- the License. You may obtain a copy of the License at -- -- http://www.apache.org/licenses/LICENSE-2.0 -- -- Unless required by applicable law or agreed to in writing, software -- distributed under the License is distributed on an "AS IS" BASIS, -- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -- See the License for the specific language governing permissions and -- limitations under the License. select 'delimiter start'; CREATE OR REPLACE FUNCTION create_index_for_x_trx_log() RETURNS void AS $$ DECLARE v_attnum1 integer := 0; v_table_exists integer := 0; BEGIN SELECT COUNT(*) INTO v_table_exists FROM pg_class WHERE relname = 'x_trx_log'; IF v_table_exists > 0 THEN select attnum into v_attnum1 from pg_attribute where attrelid in(select oid from pg_class where relname='x_trx_log') and attname in('trx_id'); IF v_attnum1 > 0 THEN IF not exists (select * from pg_index where indrelid in(select oid from pg_class where relname='x_trx_log') and indkey[0]=v_attnum1) THEN CREATE INDEX x_trx_log_IDX_trx_id ON x_trx_log(trx_id); END IF; END IF; END IF; END; $$ LANGUAGE plpgsql; select 'delimiter end'; select create_index_for_x_trx_log(); select 'delimiter end';