Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
9 / 9 / 8
Регистрация: 08.11.2014
Сообщений: 215
Записей в блоге: 1
1

Изменение поля таблицы на поле из другой таблицы

13.12.2016, 19:54. Показов 2270. Ответов 4
Метки нет (Все метки)

Есть 2 таблицы: product и prod_type
В первой хранятся продукты, во второй типы продуктов
В первой таблице есть поля p_price, p_type и другие
p_type является вторичным ключом к полю t_id из таблицы prod_type
Во второй таблице есть поле t_price
Цена продукта устанавливается в зависимости от типа продукта
Продукт типа 1 имеет цену 10
Продукт типа 2 имеет цену 15
Это к примеру
Так вот, нужно написать запрос, который и будет устанавливать эту цену
Я знаю как мне узнать сколько будет стоить мой продукт, но я не знаю как мне эту цену назначить
SQL
1
SELECT p_id, t_price FROM product p1, prod_type p2 WHERE p1.p_type = p2.t_id
Пробовал через update, написал так:
SQL
1
UPDATE product SET p_price = (SELECT t_price FROM product p1, prod_type p2 WHERE p_type = t_id)
При выполнении последнего запроса отхвачиваю ошибку, ибо запрос возвращает не одно значение (что логично)
Подскажите, пожалуйста, как мне назначить цену продукта
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
13.12.2016, 19:54
Ответы с готовыми решениями:

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

Как в поле ID одной таблицы записать значение поля ID другой таблицы
В БД две таблицы: 1)USERS с полями ID_User, Name, Password. В нее записываются пользователи...

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

Можно ли как нибудь добавить данные из 1 поля 1 таблицы в pickllist другого поля другой таблицы?
Добавить данные в picklist полю ФИО, чтоб получился выпадающий список Бред конечно, ноо... Может...

__________________
4
1037 / 854 / 334
Регистрация: 08.12.2016
Сообщений: 3,283
13.12.2016, 23:23 2
после "назначения" цены продукта product.p_price из таблицы prod_type.t_price она ещё будет меняться?
что должно происходить с product.p_price, если изменяется prod_type.t_price?
когда будет выполняться запрос если его напишешь?
0
9 / 9 / 8
Регистрация: 08.11.2014
Сообщений: 215
Записей в блоге: 1
14.12.2016, 00:11  [ТС] 3
Цитата Сообщение от YuryK Посмотреть сообщение
будет меняться?
Нет, цены меняться не будут
Сначала идёт заполнение таблицы prod_type, потом заполняется product
0
1037 / 854 / 334
Регистрация: 08.12.2016
Сообщений: 3,283
14.12.2016, 00:32 4
Лучший ответ Сообщение было отмечено avraal как решение

Решение

т.е. product.p_price должна проставляться один раз, при создании записи в product?

тогда логичнее создать триггер

T-SQL
1
2
3
4
5
6
7
8
9
10
CREATE TRIGGER Product_AfterInsert ON dbo.Product
AFTER INSERT
AS
BEGIN
  UPDATE Product SET p_price = prod_type.t_price
  FROM  
   inserted 
  JOIN Product ON inserted.p_id = Product.p_id 
  LEFT JOIN prod_type ON  inserted.p_type = prod_type.t_id
END
1
9 / 9 / 8
Регистрация: 08.11.2014
Сообщений: 215
Записей в блоге: 1
14.12.2016, 00:43  [ТС] 5
Цитата Сообщение от YuryK Посмотреть сообщение
один раз, при создании записи в product?
Именно
Спасибо за помощь
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.12.2016, 00:43

Заказываю контрольные, курсовые, дипломные работы и диссертации здесь.

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

Сложный запрос? Поля из одной таблицы, и поля из другой таблицы, но...
Вот так мы делаем выборку из основной таблицы table1: SELECT t1.ID, t1.f2, t1.f3 FROM table1 t1...

Переместить два столбца одной таблицы со строкой в поле другой таблицы
Доброго времени суток, добрый форумчанин. Возникла проблема следующего плана: Есть две таблицы:...

Внести в поле таблицы сумму значений из другой таблицы по условию
Есть две таблицы данных People (плательщики) и Pays (платежи) Необходимо при занесении нового...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.