SQL обновление одного запроса - PullRequest
1 голос
/ 23 октября 2009

Мне нужно вставить значения в новый столбец в нашей базе данных, но я не могу заставить себя делать это согласованным образом. Существует много данных, поэтому выполнение каких-либо действий вручную исключено. Позвольте мне установить сцену:

У нас есть таблица с именем Occurrence и таблица с именем OccurenceBuckets, где каждое вхождение ссылается на сегмент, которому оно было назначено. Ранее это была односторонняя ссылка, но по разным причинам мы решили добавить ссылку обратно из OccurrenceBucket к первому Occurrence (то есть впервые). Таблицы теперь выглядят так:

CREATE TABLE Occurrence
  OccurrenceID uniqueidentifier,
  OccurrenceBucketID uniqueidentifier,
  OccurrenceTime datetime,
  OccurrenceMessage nvarchar
  ...other meta data...

CREATE TABLE OccurrenceBucket
  OccurrenceBucketID uniqueidentifier,
  ...other meta data...
  FirstOccurrenceID uniqueidentifier,
  FirstOccurrenceTime datetime,
  FirstOccurrenceMessage nvarchar

Я ищу способ определения первого вхождения, принадлежащего корзине, и назначения FirstOccurrenceID, FirstOccurrenceTime и FirstOccurrenceMessage со значениями из этого первого вхождения для всех моих вхождений.

У кого-нибудь из вас есть специалисты по sql-fu, у которых есть время, чтобы помочь мне, все мои попытки увидеть неправильный или неполный отбор событий.

Ответы [ 3 ]

1 голос
/ 23 октября 2009

Вы можете попробовать это

DECLARE @Occurrence TABLE(
        OccurrenceID INT,
        OccurrenceBucketID INT,
        OccurrenceTime DATETIME,
        OccurrenceMessage VARCHAR(MAX)
)

INSERT INTO @Occurrence (OccurrenceID,OccurrenceBucketID,OccurrenceTime,OccurrenceMessage)  
SELECT 1, 1, '01 Jan 2009', 'A'
INSERT INTO @Occurrence (OccurrenceID,OccurrenceBucketID,OccurrenceTime,OccurrenceMessage)  
SELECT 2, 1, '02 Jan 2009', 'B'
INSERT INTO @Occurrence (OccurrenceID,OccurrenceBucketID,OccurrenceTime,OccurrenceMessage)  
SELECT 3, 1, '03 Jan 2009', 'C'


INSERT INTO @Occurrence (OccurrenceID,OccurrenceBucketID,OccurrenceTime,OccurrenceMessage)  
SELECT 4, 2, '04 Jan 2009', 'D'
INSERT INTO @Occurrence (OccurrenceID,OccurrenceBucketID,OccurrenceTime,OccurrenceMessage)  
SELECT 5, 2, '05 Jan 2009', 'E'
INSERT INTO @Occurrence (OccurrenceID,OccurrenceBucketID,OccurrenceTime,OccurrenceMessage)  
SELECT 6, 2, '06 Jan 2009', 'F'

SELECT * FROM @Occurrence

DECLARE @OccurrenceBucket TABLE(
        OccurrenceBucketID INT,
        FirstOccurrenceID INT,
        FirstOccurrenceTime DATETIME,
        FirstOccurrenceMessage VARCHAR(MAX)
)

INSERT INTO @OccurrenceBucket (OccurrenceBucketID) SELECT 1
INSERT INTO @OccurrenceBucket (OccurrenceBucketID) SELECT 2

SELECT * FROM @OccurrenceBucket


UPDATE  @OccurrenceBucket
SET     FirstOccurrenceID = OccurrenceID,
        FirstOccurrenceTime = OccurrenceTime,
        FirstOccurrenceMessage = OccurrenceMessage
FROM    @OccurrenceBucket oc INNER JOIN
        (
            SELECT  o.*
            FROM    @Occurrence o INNER JOIN
                    (
                        SELECT  OccurrenceBucketID,
                                MIN(OccurrenceID) FirstOccurrenceID
                        FROM    @Occurrence
                        GROUP BY OccurrenceBucketID
                    ) Mins ON o.OccurrenceID = mins.FirstOccurrenceID
        ) Vals ON oc.OccurrenceBucketID = Vals.OccurrenceBucketID

SELECT * FROM @OccurrenceBucket

EDIT:

UPDATE  @OccurrenceBucket 
SET     FirstOccurrenceID = OccurrenceID, 
        FirstOccurrenceTime = OccurrenceTime, 
        FirstOccurrenceMessage = OccurrenceMessage 
FROM    @OccurrenceBucket oc INNER JOIN 
        ( 
                SELECT  o.* 
                FROM    @Occurrence o INNER JOIN 
                                ( 
                                        SELECT  OccurrenceBucketID, 
                                                        MIN(OccurrenceTime) FirstOccurrenceTime 
                                        FROM    @Occurrence 
                                        GROUP BY OccurrenceBucketID 
                                ) Mins ON o.OccurrenceTime = mins.FirstOccurrenceTime 
        ) Vals ON oc.OccurrenceBucketID = Vals.OccurrenceBucketID 
1 голос
/ 23 октября 2009

Ну, чтобы найти первое вхождение в ведре, разве не должно работать следующее?

SELECT TOP 1
  OccurranceID, OccurranceTime, OccurranceMessage
FROM Occurance
WHERE
  OccurranceBucketID = @OccurranceBucketID
ORDER BY
  OccurranceTime ASC

Вы можете назначить возвращенные поля переменным, а затем соответствующим образом обновить OccurranceBucket.

Примечание: в "вхождении" нет "a".

0 голосов
/ 23 октября 2009

Этот ответ основан на уникальности OccurrenceTime для каждого вхождения: -

обновление набора OccBuck
OccBuck.FirstOccurrenceID = Occ.OccurrenceID,
OccBuck.FirstOccurrenceTime = Occ.OccurrenceTime,
OccBuck.FirstOccurrenceMessage = Occ.OccurrenceMessage
от
dbo.OccurrenceBucket as OccBuck
внутреннее соединение dbo.Occurrence как Occ on OccBuck.OccurrenceBucketID = Occ.OccurrenceBucketID
внутреннее соединение (выберите OccurrenceBucketID,
MIN (OccurrenceTime) как «MinOccurrenceTime»
от dbo.Occurrence
группа по OccurrenceBucketID) как minOcc по Occ.OccurrenceBucketID = minOcc.OccurrenceBucketID и
Occ.OccurrenceTime = minOcc.MinOccurrenceTime

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...