Задать вопрос
@Mamol27

Как решить ошибку «string indices must be integers» в postgresql?

В основной таблице индексом является текстовое поле. При попытке модификации этой таблицы ошибка string indices must be integers.
Запросы
-- просто добавить колонку (в планах удалить текстовые)
ALTER TABLE IF EXISTS public."P00_MAIL" ADD COLUMN "P80_SUPPLY_ID" bigint;
запрос завис
-- очистить таблицу TRUNCATE TABLE public."P00_MAIL"; запрос завис или ошибка
-- удалить текстовый индекс DROP INDEX IF EXISTS "P00_SUBJECT_IDX" RESTRICT; запрос завис
Запросы insert, update, select таблице работают. Как добавить колонку?
таблица:
-- Table: public.P00_MAIL

-- DROP TABLE IF EXISTS public."P00_MAIL";

CREATE TABLE IF NOT EXISTS public."P00_MAIL"
(
    "P00_ID" bigint NOT NULL,
    "P00_FROM" text COLLATE pg_catalog."default" NOT NULL,
    "P00_TO" text COLLATE pg_catalog."default",
    "P00_DATE_R" timestamp without time zone NOT NULL,
    "P00_DATE_S" timestamp without time zone,
    "P00_SUBJECT" text COLLATE pg_catalog."default",
    "P00_DEV_ID" text COLLATE pg_catalog."default",
    "P00_SUBJ_PART" integer,
    "P00_SUBJ_TOTAL" integer,
    "P00_ARCH" integer NOT NULL,
    "P40_ID" bigint NOT NULL,
    "P10_ID" bigint NOT NULL,
    "P51_ID" bigint,
    "P02_ID" bigint NOT NULL,
    "P04_ID" bigint NOT NULL,
    "P05_ID" bigint NOT NULL,
    "P06_ID" bigint NOT NULL,
    "P00_BODY" text COLLATE pg_catalog."default",
    "P00_PARENT_ID" bigint NOT NULL,
    "P10_ID_NEXT" bigint,
    "P54_ID" bigint,
    "P55_ID" bigint,
    "P00_FRONT_LINK" text COLLATE pg_catalog."default",
    "P53_ID" bigint,
    CONSTRAINT "P00_MAIL_pkey" PRIMARY KEY ("P00_ID"),
    CONSTRAINT "P00_MAIL_P55_ID_fkey" FOREIGN KEY ("P55_ID")
        REFERENCES public."P55_PLACE" ("P55_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION,
    CONSTRAINT "P02_FK" FOREIGN KEY ("P02_ID")
        REFERENCES public."P02_OPER_TYPE" ("P02_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P04_FK" FOREIGN KEY ("P04_ID")
        REFERENCES public."P04_REP_TYPE" ("P04_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P05_FK" FOREIGN KEY ("P05_ID")
        REFERENCES public."P05_STATE" ("P05_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P06_FK" FOREIGN KEY ("P06_ID")
        REFERENCES public."P06_DIRECTION" ("P06_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P10_FK" FOREIGN KEY ("P10_ID")
        REFERENCES public."P10_MODULE" ("P10_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P1_NEXT_FK" FOREIGN KEY ("P10_ID_NEXT")
        REFERENCES public."P10_MODULE" ("P10_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P40_FK" FOREIGN KEY ("P40_ID")
        REFERENCES public."P40_ERROR" ("P40_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P51_FK" FOREIGN KEY ("P51_ID")
        REFERENCES public."P51_ABONENT" ("P51_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID,
    CONSTRAINT "P54_FK" FOREIGN KEY ("P54_ID")
        REFERENCES public."P54_PUBLISH_PATH" ("P54_ID") MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID
)

TABLESPACE pg_default;

ALTER TABLE IF EXISTS public."P00_MAIL"
    OWNER to uta;

REVOKE ALL ON TABLE public."P00_MAIL" FROM PUBLIC;

GRANT ALL ON TABLE public."P00_MAIL" TO uta;

GRANT SELECT ON TABLE public."P00_MAIL" TO PUBLIC;

COMMENT ON TABLE public."P00_MAIL"
    IS 'входящие сообщения';
-- Index: P00_DATE_R_IDX

-- DROP INDEX IF EXISTS public."P00_DATE_R_IDX";

CREATE INDEX IF NOT EXISTS "P00_DATE_R_IDX"
    ON public."P00_MAIL" USING btree
    ("P00_DATE_R" ASC NULLS LAST)
    TABLESPACE pg_default;
-- Index: P00_DEV_ID_IDX

-- DROP INDEX IF EXISTS public."P00_DEV_ID_IDX";

CREATE INDEX IF NOT EXISTS "P00_DEV_ID_IDX"
    ON public."P00_MAIL" USING btree
    ("P00_DEV_ID" COLLATE pg_catalog."default" ASC NULLS LAST)
    TABLESPACE pg_default;
-- Index: P00_PARENT_ID_IDX

-- DROP INDEX IF EXISTS public."P00_PARENT_ID_IDX";

CREATE INDEX IF NOT EXISTS "P00_PARENT_ID_IDX"
    ON public."P00_MAIL" USING btree
    ("P00_PARENT_ID" ASC NULLS LAST)
    TABLESPACE pg_default;
-- Index: P00_SUBJECT_IDX

-- DROP INDEX IF EXISTS public."P00_SUBJECT_IDX";

CREATE INDEX IF NOT EXISTS "P00_SUBJECT_IDX"
    ON public."P00_MAIL" USING btree
    ("P00_SUBJECT" COLLATE pg_catalog."default" ASC NULLS LAST)
    TABLESPACE pg_default;
-- Index: P10_ID_IDX

-- DROP INDEX IF EXISTS public."P10_ID_IDX";

CREATE INDEX IF NOT EXISTS "P10_ID_IDX"
    ON public."P00_MAIL" USING btree
    ("P10_ID" ASC NULLS LAST)
    TABLESPACE pg_default;
-- Index: P40_ID_IDX

-- DROP INDEX IF EXISTS public."P40_ID_IDX";

CREATE INDEX IF NOT EXISTS "P40_ID_IDX"
    ON public."P00_MAIL" USING btree
    ("P40_ID" ASC NULLS LAST)
    TABLESPACE pg_default;
  • Вопрос задан
  • 442 просмотра
Подписаться 1 Простой 6 комментариев
Пригласить эксперта
Ответы на вопрос 2
Melkij
@Melkij
PostgreSQL DBA
В postgresql такого текста ошибки нет.

Этот запрос висит вечно

Значит другие транзакции не дают вам получить access exclusive lock. (note: пока такой alter table в очереди ожидания - проект лежит)
Посмотрите в pg_stat_activity что у вас запущено. например вот так
Ответ написан
mayton2019
@mayton2019
Bigdata Engineer
Здравствуйте, мне в наследство досталась база где в основной таблице индексом является текстовое поле.

Это не является ошибкой. Возможно в дизайн закладывался текстовый ключ. Ну по крайней мере у тебя нет острой необходимости всё ломать сразу.

Вообще такие страшные вещи которые ты затеял - делаются в специальные периоды времени. В окна обслуживания и предварительно всех предупредив.
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы