Для изменения уже имеющихся строк в таблице применяется команда UPDATE. Она имеет следующий формальный синтаксис:
1
2
3
4
| UPDATE имя_таблицыSET столбец1 = значение1, столбец2 = значение2, ... столбецN = значениеN[FROM выборка AS псевдоним_выборки][WHERE условие_обновления] |
Например, увеличим у всех товаров цену на 5000:
1
2
| UPDATE ProductsSET Price = Price + 5000 |

Используем критерий, и изменим название производителя с "Samsung" на "Samsung Inc.":
1
2
3
| UPDATE ProductsSET Manufacturer = 'Samsung Inc.'WHERE Manufacturer = 'Samsung' |
Более сложный запрос - заменим у поля Manufacturer значение "Apple" на "Apple Inc." в первых 2 строках:
1
2
3
4
5
| UPDATE ProductsSET Manufacturer = 'Apple Inc.'FROM(SELECT TOP 2 * FROM Products WHERE Manufacturer='Apple') AS SelectedWHERE Products.Id = Selected.Id |
С помощью подзапроса после ключевого слова FROM производится выборка первых двух строк, в которых Manufacturer='Apple'. Для этой выборки будет определен псевдоним Selected. Псевдоним указывается после оператора AS.
Далее идет условие обновления
Products.Id = Selected.Id. То есть фактически мы имеем дело с двумя таблицами - Products и Selected (которая является производной от Products). В Selected находится две первых строки, в которых Manufacturer='Apple'. В Products - вообще все строки. И обновление производится только для тех строк, которые есть в выборке Selected. То есть если в таблице Products десятки товаров с производителем Apple, то обновление коснется только двух первых из них.
Комментариев нет:
Отправить комментарий