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

Коллеги, подскажите плиз. В бд есть поле varchar2(2000) оно уже

заполненное. Щас выяснили что места не хватает. Задача сделать его varchar2(32000). Если я накачу изменения размерности поля, проблем не будет?

9 ответов

12 просмотров

https://docs.oracle.com/database/121/REFRN/GUID-D424D23B-0933-425F-BC69-9C0E6724693C.htm#REFRN10321

Vlad Kutuev- Автор вопроса

спасибо

Смотря как обьявляли пересенные в связанных обьектах.)

Vlad Kutuev- Автор вопроса

не, это не связанное поле, просто в нем дофига текста

лучше ограничиться 4000. Если надо больше, то можно нарваться на какие-то баги MAX_STRING_SIZE=extended. Возможно, что проще будет заменить varchar2 на clob или бить на несколько полей

Vlad Kutuev- Автор вопроса

не, задачу поставили увеличить до 32тыс

По идее alter table мгновенно выполнится, это же ведь обновление метаданных таблицы. Но если у тебя будут update записей с обновлением значения этого столбца на более длинное, то хз, что Оракл сделает. Одну часть строки сохранит в одном блоке, а другую часть переместит в другой? Или переместит всю строку? Может быть чревато перформансом при последующих селектах. А для новых записей наверное всё будет ок. Ну а clob использовать это такое, сразу куча гемора появляется.

Vlad Kutuev- Автор вопроса

спасибо, да поэтму от clob отказались

Max_string_size = extended на самом деле тоже clob внутри скрытый при размере больше _scalar_type_lob_storage_threshold: http://orasql.org/2013/07/13/oracle-12c-extended-varchars/

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

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

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
А чем вам питонисты не угодили?😂
.
79
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Всем привет. Поделитесь, пожалуйста, опытом. Есть форма, на которой имеется dbgrid и кнопки: добавить, редактировать, удалить. Если нет записей в dbgrid, то кнопки редактирова...
Евгений
5
type TExtensions<GExtender>=class function GetExtension<GEntityExtenderType>:GEntityExtenderType; end; function TExtensions<GExtender>.GetExtension<GEntityExtenderType...
zamtmn
8
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Всем привет, препод задал вопрос, подскажите пожалуйста, какой адрес инкапсулирует указатель?
Свинка Пеппа
8
Почему никто ещё не написал квантовую виртуальную машину на Windows?
КТ315
7
Вот смотрите у меня есть два стрима сейчас fs, cs: TStream; fs := TFileStream.Create('filename'); cs := TCompressionStream.Create(compression_level, fs); Я хочу сделать так: ...
notme
5
Карта сайта