Как сделать INSERT в таблицу записей, извлеченных из другой таблицы


177

Я пытаюсь написать запрос, который извлекает и преобразует данные из таблицы, а затем вставляет эти данные в другую таблицу. Да, это запрос хранилища данных, и я делаю это в MS Access. Так что в основном я хочу такой запрос:

INSERT INTO Table2(LongIntColumn2, CurrencyColumn2) VALUES
  (SELECT LongIntColumn1, Avg(CurrencyColumn) as CurrencyColumn1 FROM Table1 GROUP BY LongIntColumn1);

Я пытался, но получил сообщение об ошибке синтаксиса.

Что бы вы сделали, если хотите это сделать?

Ответы:


283

Без «ЗНАЧЕНИЙ», без круглых скобок:

INSERT INTO Table2(LongIntColumn2, CurrencyColumn2)
SELECT LongIntColumn1, Avg(CurrencyColumn) as CurrencyColumn1 FROM Table1 GROUP BY LongIntColumn1;

11
на самом деле, если нет. столбцов и их типов одинаковы, и они выходят в таблицах в одном и том же порядке, тогда вы можете просто сказать, INSERT INTO Table2 SELECT * FROM table1;
Саквояж

28

У вас есть два варианта синтаксиса:

Опция 1

CREATE TABLE Table1 (
    id int identity(1, 1) not null,
    LongIntColumn1 int,
    CurrencyColumn money
)

CREATE TABLE Table2 (
    id int identity(1, 1) not null,
    LongIntColumn2 int,
    CurrencyColumn2 money
)

INSERT INTO Table1 VALUES(12, 12.00)
INSERT INTO Table1 VALUES(11, 13.00)

INSERT INTO Table2
SELECT LongIntColumn1, Avg(CurrencyColumn) as CurrencyColumn1 FROM Table1 GROUP BY LongIntColumn1

Вариант 2

CREATE TABLE Table1 (
    id int identity(1, 1) not null,
    LongIntColumn1 int,
    CurrencyColumn money
)

INSERT INTO Table1 VALUES(12, 12.00)
INSERT INTO Table1 VALUES(11, 13.00)


SELECT LongIntColumn1, Avg(CurrencyColumn) as CurrencyColumn1
INTO Table2
FROM Table1
GROUP BY LongIntColumn1

Имейте в виду, что в варианте 2 будет создана таблица с только столбцами в проекции (те, что в SELECT).


24

Удалить оба значения и скобки.

INSERT INTO Table2 (LongIntColumn2, CurrencyColumn2)
SELECT LongIntColumn1, Avg(CurrencyColumn) FROM Table1 GROUP BY LongIntColumn1


10

Я полагаю, что вашей проблемой в этом случае является ключевое слово "values". Вы используете ключевое слово «values», когда вставляете только одну строку данных. Для вставки результатов выбора вам это не нужно.

Кроме того, вам действительно не нужны скобки вокруг оператора select.

Из MSDN :

Запрос на добавление нескольких записей:

INSERT INTO target [(field1[, field2[, …]])] [IN externaldatabase]
SELECT [source.]field1[, field2[, …]
FROM tableexpression

Запрос на добавление одной записи:

INSERT INTO target [(field1[, field2[, …]])]     
VALUES (value1[, value2[, …])

4

Удалите «значения» при добавлении группы строк и удалите лишние скобки. Вы можете избежать циклической ссылки, используя псевдоним для avg (CurrencyColumn) (как вы сделали в вашем примере) или вообще не используя псевдоним.

Если имена столбцов одинаковы в обеих таблицах, ваш запрос будет выглядеть так:

INSERT INTO Table2 (LongIntColumn, Junk)
SELECT LongIntColumn, avg(CurrencyColumn) as CurrencyColumn1
FROM Table1
GROUP BY LongIntColumn;

И это будет работать без псевдонима:

INSERT INTO Table2 (LongIntColumn, Junk)
SELECT LongIntColumn, avg(CurrencyColumn)
FROM Table1
GROUP BY LongIntColumn;

2

Ну, я думаю, что лучшим способом было бы (будет?) Определить 2 набора записей и использовать их в качестве промежуточного звена между двумя таблицами.

  1. Откройте оба набора записей
  2. Извлечь данные из первой таблицы (SELECT blablabla)
  3. Обновите 2-й набор записей данными, доступными в первом наборе записей (добавив новые записи или обновив существующие записи).
  4. Закройте оба набора записей

Этот метод особенно интересен, если вы планируете обновлять таблицы из разных баз данных (т.е. каждый набор записей может иметь свое собственное соединение ...)


2

вставка данных из одной таблицы в другую таблицу в другой базе данных

insert into DocTypeGroup 
    Select DocGrp_Id,DocGrp_SubId,DocGrp_GroupName,DocGrp_PM,DocGrp_DocType 
    from Opendatasource( 'SQLOLEDB','Data Source=10.132.20.19;UserID=sa;Password=gchaturthi').dbIPFMCI.dbo.DocTypeGroup

1

Вы хотите вставить извлечение в существующую таблицу?

Если это не имеет значения, вы можете попробовать следующий запрос:

SELECT LongIntColumn1, Avg(CurrencyColumn) as CurrencyColumn1 INTO T1 FROM Table1 
GROUP BY LongIntColumn1);

Это создаст новую таблицу -> T1 с извлеченной информацией

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.