Вставка данных в таблицу с результатом другого запроса выбора
Я ищу помощь по следующей проблеме:
У меня две таблицы
Table_1
столбцы: itemid
, locationid
, quantity
Table_2
столбцы itemid
, location1
, location2
, location3
Я хочу скопировать данные из Table_1
(только столбца quantity
) в столбец Table_2
(в столбце location1
). itemid
одинаковы в обеих таблицах (Table_1
имеет одинаковые идентификаторы элементов), поэтому я хочу скопировать в новую таблицу и сохранить все количество в одной строке с каждым местоположением в качестве столбца. Я использую следующий запрос, но он не работает.
INSERT INTO
Table_2(location1)
(
SELECT qty
FROM Table_1
WHERE locationid = 1 AND Table_1.locationid = Table_2.locationid
)
Ответы
Ответ 1
Если table_2
пусто, попробуйте следующую инструкцию insert:
insert into table_2 (itemid,location1)
select itemid,quantity from table_1 where locationid=1
Если table_2
уже содержит значения itemid
, попробуйте этот оператор обновления:
update table_2 set location1=
(select quantity from table_1 where locationid=1 and table_1.itemid = table_2.itemid)
Ответ 2
INSERT INTO `test`.`product` ( `p1`, `p2`, `p3`)
SELECT sum(p1), sum(p2), sum(p3)
FROM `test`.`product`;
Ответ 3
Ниже приведен пример такого запроса:
INSERT INTO [93275].[93276].[93277].[93278] ( [Mobile Number], [Mobile Series], [Full Name], [Full Address], [Active Date], company ) IN 'I:\For Test\90-Mobile Series.accdb
SELECT [1].[Mobile Number], [1].[Mobile Series], [1].[Full Name], [1].[Full Address], [1].[Active Date], [1].[Company Name]
FROM 1
WHERE ((([1].[Mobile Series])="93275" Or ([1].[Mobile Series])="93276")) OR ((([1].[Mobile Series])="93277"));OR ((([1].[Mobile Series])="93278"));