172 похожих чатов

Как поменять Data Type в уже существующей таблице? pgAdmin просто не

выводит список из типов другого вида (для character varying только name, text т.д.).
При попытке поменять через ALTER TABLE table_name ALTER COLUMN column_name TYPE jsonb выдаёт ошибку, column "column_name" cannot be cast automatically to type jsonb

12 ответов

47 просмотров

Так не выйдет, нет правила преобразования из varchar в jsonb

Khazif- Автор вопроса
Khazif- Автор вопроса
Khazif
Жесть

Таков путь. "Таблица пустая" - слишком слабое допущение для многопользовательской БД.

Khazif- Автор вопроса
Sergey Bezrukov
drop column, add column

Спасибо, буду копать

так попробуйте alter table tbl_name ALTER COLUMN column_name TYPE jsonb using to_jsonb(column_name);

Khazif- Автор вопроса
Khazif- Автор вопроса

Замечу, что если в таблицэ 100500 данных и ALTER .. USING создаёт проблемы со скоростью -- то можно добавить столбец, перегнать в него данные хоть по частям, потом удалить предыдущий столбец и переименовать новый (последнее -- можно в транзакцыи если шьёте "на жывую").

Ilya Anfimov
Замечу, что если в таблицэ 100500 данных и ALTER ....

если этот столбец PK или на него есть REFERENCES, то всё чутка интересней становится…

Виктор Егоров
если этот столбец PK или на него есть REFERENCES, ...

Ну так, умеренно. То есть PK -- вообще не проблема, создаёшь уникальный индэкс, потом оно почти мгновенно переименовывается. CONSTRAINT переделывать -- ну, так, но с ALTER TABLE ... ADD CONSTRAINT ... NOT VALID -- в общем, всё тожэ в бэкграунде делается.

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

Обсуждают сегодня

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
Кибер Бомж
8
Карта сайта