1с переименовать колонку таблицы значений

лПЗДБ ЧЩ УПЪДБМЙ ФБВМЙГХ Й ЧЙДЙФЕ, ЮФП ДПРХУФЙМЙ ПЫЙВЛХ ЙМЙ ЮФП ФТЕВПЧБОЙС РТЙМПЦЕОЙС ЙЪНЕОЙМЙУШ, ЧЩ НПЦЕФЕ ХДБМЙФШ ЬФХ ФБВМЙГХ Й УПЪДБФШ ЕЈ ЪБОПЧП. оП ЬФП ОЕХДПВОП, ЕУМЙ ФБВМЙГБ ХЦЕ УПДЕТЦЙФ ДБООЩЕ ЙМЙ ЕУМЙ ОБ ФБВМЙГХ УУЩМБАФУС ДТХЗЙЕ ПВЯЕЛФЩ ВБЪЩ ДБООЩИ (ОБРТЙНЕТ, ЧОЕЫОЙК ЛМАЮ). рПЬФПНХ PostgreSQL РТЕДПУФБЧМСЕФ ОБВПТ ЛПНБОД ДМС ЧОЕУЕОЙС ЙЪНЕОЕОЙК Ч УХЭЕУФЧХАЭЙЕ ФБВМЙГЩ. ъБНЕФЙН, ЮФП ЬФЙ ДЕКУФЧЙС ЛПОГЕРФХБМШОП ПФМЙЮБАФУС ПФ ЙЪНЕОЕОЙК УБНЙИ ДБООЩИ, УПДЕТЦБЭЙИУС Ч ФБВМЙГЕ: ЪДЕУШ НЩ ЗПЧПТЙН П ЙЪНЕОЕОЙЙ УФТХЛФХТЩ ФБВМЙГЩ.

йЪНЕОЙФШ ЪОБЮЕОЙС РП ХНПМЮБОЙА,

йЪНЕОЙФШ ФЙРЩ ДБООЩИ ЛПМПОПЛ,

чУЕ ЬФЙ ДЕКУФЧЙС ЧЩРПМОСАФУС У РПНПЭША ЛПНБОДЩ ALTER TABLE .

юФПВЩ ДПВБЧЙФШ ЛПМПОЛХ, ЙУРПМШЪХКФЕ ЛПНБОДХ ЧЙДБ:

ALTER TABLE products ADD COLUMN description text;

оПЧБС ЛПМПОЛБ ЙЪОБЮБМШОП ЪБРПМОСЕФУС ХЛБЪБООЩН ЪОБЮЕОЙЕН РП ХНПМЮБОЙА (ЪОБЮЕОЙЕН null, ЕУМЙ ЧЩ ОЕ ЪБДБМЙ ДТХЗПЕ ЪОБЮЕОЙЕ Ч РТЕДМПЦЕОЙЙ DEFAULT ).

фБЛЦЕ Ч ЬФПФ НПНЕОФ, ЧЩ НПЦЕФЕ ЪБДБФШ ПЗТБОЙЮЕОЙС ОБ ЛПМПОЛХ, ЙУРПМШЪХС УЙОФБЛУЙУ ЧЙДБ:

ALTER TABLE products ADD COLUMN description text CHECK (description <> »);

жБЛФЙЮЕУЛЙ, ЧУЕ ПРГЙЙ, ЛПФПТЩЕ ЙУРПМШЪХАФУС РТЙ ЧЩРПМОЕОЙЙ ЛПНБОДЩ CREATE TABLE , НПЗХФ ВЩФШ РТЙНЕОЕОЩ Й ЪДЕУШ. пДОБЛП, ДЕТЦЙФЕ Ч ХНЕ, ЮФП ЪОБЮЕОЙЕ РП ХНПМЮБОЙА ДПМЦОП ХДПЧМЕФЧПТСФШ ЪБДБООЩН ПЗТБОЙЮЕОЙСН, ЙОБЮЕ ЧЩРПМОЕОЙЕ ADD ЪБЛПОЮЙФУС ПЫЙВЛПК. ч ЛБЮЕУФЧЕ БМШФЕТОБФЙЧЩ, ЧЩ НПЦЕФЕ ДПВБЧЙФШ ПЗТБОЙЮЕОЙС РПЪЦЕ (УН. ОЙЦЕ), РПУМЕ ФПЗП ЛБЛ ЧЩ ЛПТТЕЛФОП ЪБЛПОЮЙМЙ ДПВБЧМЕОЙЕ ОПЧПК ЛПМПОЛЙ.

юФПВЩ ХДБМЙФШ ЛПМПОЛХ, ЙУРПМШЪХКФЕ ЛПНБОДХ ЧЙДБ:

ALTER TABLE products DROP COLUMN description;

дБООЩЕ Ч ЬФПК ЛПМПОЛЕ ВХДХФ РПФЕТСОЩ. пЗТБОЙЮЕОЙС, ЛБУБАЭЙЕУС ЬФПК ЛПМПОЛЙ ФБЛЦЕ ВХДХФ ХДБМЕОЩ. пДОБЛП, ЕУМЙ ОБ ЛПМПОЛХ УУЩМБЕФУС ПЗТБОЙЮЕОЙЕ ЧОЕЫОЕЗП ЛМАЮБ ДТХЗПК ФБВМЙГЩ, ФП PostgreSQL ОЕ ВХДЕФ НПМЮБ ХДБМСФШ ЬФП ПЗТБОЙЮЕОЙЕ. чЩ НПЦЕФЕ СЧОП ХЛБЪБФШ ХДБМЕОЙЕ ЪБЧЙУСЭЕЗП ПФ ЛПМПОЛЙ ПЗТБОЙЮЕОЙС, ДПВБЧЙЧ CASCADE :

ALTER TABLE products DROP COLUMN description CASCADE;

уН. ПРЙУБОЙЕ ЬФПЗП НЕИБОЙЪНБ Ч Section 5.11 .

юФПВЩ ДПВБЧЙФШ ЛБЛПЕ-МЙВП ПЗТБОЙЮЕОЙЕ, ЙУРПМШЪХЕФУС ФБВМЙЮОЩК УЙОФБЛУЙУ ПРТЕДЕМЕОЙС ЬФПЗП ПЗТБОЙЮЕОЙС. оБРТЙНЕТ:

ALTER TABLE products ADD CHECK (name <> »); ALTER TABLE products ADD CONSTRAINT some_name UNIQUE (product_no); ALTER TABLE products ADD FOREIGN KEY (product_group_id) REFERENCES product_groups;

юФПВЩ ДПВБЧЙФШ ПЗТБОЙЮЕОЙЕ ОЕ-null, ЛПФПТПЕ ОЕМШЪС ЪБРЙУБФШ ЛБЛ ПЗТБОЙЮЕОЙЕ ОБ ФБВМЙГХ, ЙУРПМШЪХКФЕ УЙОФБЛУЙУ:

ALTER TABLE products ALTER COLUMN product_no SET NOT NULL;

хЛБЪБООПЕ ПЗТБОЙЮЕОЙЕ ВХДЕФ ЪБДЕКУФЧПЧБОП ОЕНЕДМЕООП, ФБЛ ЮФП ДБООЩЕ Ч ФБВМЙГЕ РЕТЕД ДПВБЧМЕОЙЕН ПЗТБОЙЮЕОЙС ДПМЦОЩ ЕНХ ХДПЧМЕОФЧПТСФШ.

юФПВЩ ХДБМЙФШ ПЗТБОЙЮЕОЙЕ, ЧБН ОЕПВИПДЙНП ЪОБФШ ЕЗП ЙНС. еУМЙ ЧЩ УБНЙ ДБЧБМЙ ЕНХ ЙНС, ФП ЧУЕ РТПУФП. ч РТПФЙЧОПН УМХЮБЕ, ухвд ОБЪОБЮЙМП БЧФПНБФЙЮЕУЛЙ УЗЕОЕТЙТПЧБООПЕ ЙНС, ЛПФПТПЕ ОХЦОП ОБКФЙ. ч ЬФПН НПЦЕФ РПНПЮШ ЛПНБОДБ d tablename Ч psql ; ДТХЗЙЕ ЙОФЕТЖЕКУЩ ФБЛЦЕ НПЗХФ РТЕДПУФБЧМСФШ УРПУПВ ЙОУРЕЛФЙТПЧБОЙС РПДТПВОПУФЕК ФБВМЙГ. ъБФЕН ЧЩРПМОСЕФУС ЛПНБОДБ:

ALTER TABLE products DROP CONSTRAINT some_name;

(еУМЙ ЧЩ ЧЩРПМОСЕФЕ ЛПНБОДХ У ХЛБЪБОЙЕН ФБЛПЗП ЙНЕОЙ ПЗТБОЙЮЕОЙС ЛБЛ $2 , ОЕ ЪБВХДШФЕ, ЮФП ЧБН РПОБДПВЙФУС ЪБЛМАЮЙФШ ЙНС Ч ДЧПКОЩЕ ЛБЧЩЮЛЙ, ЮФПВЩ ЙНС ВЩМП ЧПУРТЙОСФП ЛБЛ РТБЧЙМШОЩК ЙДЕОФЙЖЙЛБФПТ.)

лБЛ Й Ч УМХЮБЕ У ХДБМЕОЙЕН ЛПМПОЛЙ, ЧБН РПОБДПВЙФУС ДПВБЧЙФШ CASCADE , ЕУМЙ ЧЩ ИПФЙФЕ ХДБМЙФШ ПЗТБОЙЮЕОЙЕ, ПФ ЛПФПТПЗП ЪБЧЙУЙФ ЮФП МЙВП ДТХЗПЕ. оБРТЙНЕТ, ЕУМЙ ОЕЛПЕ ПЗТБОЙЮЕОЙЕ ЧОЕЫОЕЗП ЛМАЮБ ЪБЧЙУЙФ ПФ ПЗТБОЙЮЕОЙС ХОЙЛБМШОПУФЙ ЙМЙ РЕТЧЙЮОПЗП ЛМАЮБ ДМС УУЩМПЮОПК ЛПМПОЛЙ(ПЛ).

фЕ ЦЕ РТБЧЙМБ ТБВПФБАФ ДМС ЧУЕИ ЧЙДПЧ ПЗТБОЙЮЕОЙК, ЙУЛМАЮБС ПЗТБОЙЮЕОЙС ОЕ-null. юФПВЩ ХДБМЙФШ ПЗТБОЙЮЕОЙЕ ОЕ-null, ЙУРПМШЪХКФЕ

ALTER TABLE products ALTER COLUMN product_no DROP NOT NULL;

(пВТБФЙФЕ ЧОЙНБОЙЕ, ЮФП ПЗТБОЙЮЕОЙС ОЕ-null ОЕ ЙНЕАФ ЙНЕОЙ.)

юФПВЩ ХУФБОПЧЙФШ ОПЧПЕ ЪОБЮЕОЙЕ РП ХНПМЮБОЙА ДМС ЛПМПОЛЙ, ЙУРПМШЪХКФЕ ЛПНБОДХ ЧЙДБ:

ALTER TABLE products ALTER COLUMN price SET DEFAULT 7.77;

ъБНЕФЙН, ЮФП ЧЩРПМОЕОЙЕ ДБООПК ЛПНБОДЩ ОЕ ЧМЙСЕФ ОБ ХЦЕ УХЭЕУФЧХАЭЙЕ УФТПЛЙ Ч ФБВМЙГЕ, ЛПНБОДБ ЙЪНЕОСФ ЪОБЮЕОЙЕ РП ХНПМЮБОЙА ФПМШЛП ДМС ВХДХЭЙИ ЛПНБОД INSERT .

юФПВЩ ХДБМЙФШ МАВПЕ ЪОБЮЕОЙЕ РП ХНПМЮБОЙА, ЙУРПМШЪХКФЕ

ALTER TABLE products ALTER COLUMN price DROP DEFAULT;

лПНБОДБ ЧЩРПМОСЕФ ФПЦЕ УБНПЕ, ЮФП Й ХУФБОПЧЛБ ЪОБЮЕОЙС РП ХНПМЮБОЙА Ч null. рПУЛПМШЛХ РТЙ ХДБМЕОЙЙ ЪОБЮЕОЙС РП ХНПМЮБОЙА, ПОП ОЕСЧОП ХУФБОБЧМЙЧБЕФУС Ч null, Ч УМХЮБЕ ХДБМЕОЙС УХЭЕУФЧХАЭЕЗП ЪОБЮЕОЙС РП ХНПМЮБОЙА, УППВЭЕОЙК ПВ ПЫЙВЛБИ, ОЕ ВХДЕФ.

юФПВЩ РТЕПВТБЪПЧБФШ ЛПМПОЛХ Л ДТХЗПНХ ФЙРХ ДБООЩИ, ЙУРПМШЪХКФЕ ЛПНБОДХ ЧЙДБ:

ALTER TABLE products ALTER COLUMN price TYPE numeric(10,2);

лПНБОДБ ЧЩРПМОЙФУС ХУРЕЫОП ФПМШЛП ЕУМЙ ЛБЦДБС УХЭЕУФЧХАЭБС ЪБРЙУШ Ч ЛПМПОЛЕ НПЦЕФ ВЩФШ РТЕПВТБЪПЧБОБ Л ОПЧПНХ ФЙРХ ЮЕТЕЪ ОЕСЧОПЕ РТЙЧЕДЕОЙЕ ФЙРБ. еУМЙ ОЕПВИПДЙНП ВПМЕЕ УМПЦОПЕ РТЕПВТБЪПЧБОЙЕ, ЧБН ОХЦОП ДПВБЧЙФШ РТЕДМПЦЕОЙЕ USING , ЛПФПТПЕ ПРТЕДЕМСЕФ ЛБЛ ЙЪ УФБТПЗП ЪОБЮЕОЙС ВХДЕФ РПМХЮЕОП ОПЧПЕ.

PostgreSQL ВХДЕФ РЩФБФШУС РТЕПВТБЪПЧБФШ Л ОПЧПНХ ФЙРХ ЪОБЮЕОЙЕ РП ХНПМЮБОЙА, ЪБДБООПЕ ДМС ЛПМПОЛЙ, Б ФБЛЦЕ ЧУЕ ПЗТБОЙЮЕОЙС, УЧСЪБООЩЕ У ЬФПК ЛПМПОЛПК. оП ЬФЙ РТЕПВТБЪПЧБОЙС НПЗХФ ЪБЧЕТЫЙФШУС ПЫЙВЛПК ЙМЙ НПЗХФ РТЙЧЕУФЙ Л ОЕПЦЙДБООЩН ТЕЪХМШФБФБН. юБУФП, МХЮЫЕ ХДБМЙФШ ЧУЕ ПЗТБОЙЮЕОЙС ОБ ЛПМПОЛХ РЕТЕД ФЕН ЛБЛ ЙЪНЕОЙФШ ЕЈ ФЙР, Б ЪБФЕН ДПВБЧЙФШ УППФЧЕФУФЧЕООП ЙЪНЕОЈООЩЕ ПЗТБОЙЮЕОЙС ПВТБФОП.

юФПВЩ РЕТЕЙНЕОПЧБФШ ЛПМПОЛХ, ЙУРПМШЪХКФЕ ЛПНБОДХ ЧЙДБ:

ALTER TABLE products RENAME COLUMN product_no TO product_number;

юФПВЩ РЕТЕЙНЕОПЧБФШ ФБВМЙГХ, ЙУРПМШЪХКФЕ ЛПНБОДХ ЧЙДБ:

Все довольно просто. Итак, предположим, у нас есть таблица значений (неважно, хранится она у нас как программный объект или является элементом формы) следующей структуры:

Чтобы переименовать колонку таблицы значений достаточно написать следующий нехитрый код:

В дальнейшем, при обращении к колонке из встроенного языка, нужно использовать новое имя колонки:

Описание:

Таблица значений — это несохраняемый в базе данных объект, который позволяет строить динамические наборы значений и манипулировать ими (добавлять, редактировать, удалять элементы, сортировать). Он может быть наполнен значениями любого типа, т.е. в одной таблице типы хранимых значений могут быть разными. Одним из примеров использования данного объекта может служить организация представления в форме списка элементов справочника, отобранных по сложному алгоритму.

Необходимо отметить, что таблица значений, связанная с элементом управления ТабличноеПоле, будет иметь все колонки, имеющиеся в табличном поле, с соответствующими именами. Кроме того, таблица значений может иметь также и собственные колонки, не отображаемые в табличном поле, при этом их имена должны отличаться от имен колонок табличного поля.

Элементы коллекции: СтрокаТаблицыЗначений

Для объекта доступен обход коллекции посредством оператора Для каждого … Из … Цикл. При обходе выбираются элементы коллекции.

Возможно обращение к элементу коллекции посредством оператора [. ]. В качестве аргумента передается индекс строки (нумерация с 0).

Понравилась статья? Поделиться с друзьями:
Vkontakte.INFO
Добавить комментарий

;-) :| :x :twisted: :smile: :shock: :sad: :roll: :razz: :oops: :o :mrgreen: :lol: :idea: :grin: :evil: :cry: :cool: :arrow: :???: :?: :!: