it-swarm-ru.tech

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

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

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

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

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

172
Martin08

Без "ЗНАЧЕНИЙ", без скобок:

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

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

Вариант 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).

25
Jorge Ferreira

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

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

Удалите VALUES из вашего SQL.

10
Forgotten Semicolon

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

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

От MSDN :

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

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

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

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

Удалите "значения" при добавлении группы строк и удалите лишние скобки. Вы можете избежать циклической ссылки, используя псевдоним для 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;
4
Chris OC

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

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
2
PRITESH PARMAR PINTOO

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

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

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

2
Philippe Grondier

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

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

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

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

1
Ashwin