ОБНОВЛЕНИЕ ДАННЫХ (инструкция UPDATE)

 

Инструкция UPDATE обновляет значения одного или нескольких столбцов в выбранных строках одной таблицы.

 

update имя_таблицы

set имя_столбца_1=значение_1 [, имя_столбца_2=значение_2 …]

[WHERE условие];

 

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

 

Увеличить заработную плату менеджеров на 10%

update staff

set salary=salary*1.1

WHERE position=‘manager’;

 

Условия отбора, которые могут быть заданы в предложении WHERE инструкции UPDATE, в точности соответствуют условиям отбора, доступным в инструкциях SELECT и DELETE.

Как и инструкция DELETE, инструкция UPDATE может одновременно обновить несколько строк, соответствующих условию отбора. Например:

 

Перевести всех служащих из отделения № 2 в отделение № 1

update staff

set bno=1

WHERE bno=2;

 

Предложение SET в инструкции представляет собой список операций присваивания, отделяемых друг от друга запятыми. В каждой операции идентифицируется столбец, который должен обновляться, и определяется новое значение для этого столбца. Каждый целевой столбец должен встречаться в списке только один раз. Согласно стандарту ANSI/ISO, для столбцов необходимо использовать простые имена, но некоторые СУБД допускают использование полных имен столбцов.

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

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

Обновление всех строк. Предложение WHERE в инструкции UPDATE является необязательным. Если оно опущено, то обновляются все строки целевой таблицы. Например:

 

Увеличить заработную плату всех сотрудников на 5%:

update staff

set salary=1.05*salary;

 

Инструкции UPDATE с подчиненным запросом. В инструкции UPDATE, так же как и в инструкции DELETE, подчиненные запросы могут играть важную роль, поскольку они дают возможность отбирать строки для обновления, опираясь на информацию из других таблиц. Например:

 

Всем служащим отделения Минского отделения увеличить зарплату на 10%

update staff

set salary=1.1*salary

WHERE bno IN (SELECT bno

FROM branch

WHERE city=‘Минск’);

 

Подчиненные запросы в предложении WHERE инструкции UPDATE, так же как и в инструкции DELETE, могут иметь любой уровень вложенности и содержать внешние ссылки на целевую таблицу инструкции UPDATE.

Инструкция MERGE. Начиная с версии Oracle 9i, появилась возможность использовать инструкцию MERGE INTO, которая объединяет в себе возможности инструкций вставки, обновления и удаления, делая их более удобными для пользователей.

Общий синтаксис инструкции MERGE INTO:

 

MERGE INTO destination_table dest

USING (SELECT col1, col2, col3 FROM source_table) source1

ON (dest.col1 = source1.col1)

WHEN MATCHED THEN

UPDATE SET dest.col2 = source1.col2,

dest.col3 = source1.col3

WHERE source1.col2 IS NOT NULL

DELETE source1.col2 IS NULL

WHEN NOT MATCHED THEN

INSERT (dest.col1, dest.col2, dest.col3)

VALUES (source1.col1, source1.col2, source1.col3)

WHERE source1.col2 IS NOT NULL

 

Пример использования:

 

MERGE INTO copy_emp c

USING employees e

ON (c.employee_id = e.employee_id)

WHEN MATCHED THEN

UPDATE SET

c.first_name = e.first_name,

c.last_name = e.last_name,

c.department_id = e.department_id

WHEN NOT MATCHED THEN

INSERT VALUES(e.employee_id, e.first_name, e.last_name,

e.email, e.phone_number, e.hire_date, e.job_id,

e.salary, e.commission_pct, e.manager_id,

e.department_id);

 

 








Дата добавления: 2015-08-26; просмотров: 811;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.009 сек.