2017-01-15 40 views
0

我試圖根據列的值(updated_at)計算每條記錄的權重。當我運行以下查詢:使用子查詢更新爲所有記錄設置相同的值

UPDATE buyers 
SET weight = RankedRecords.rank/(RankedRecords.count + 1.0) 
FROM (
    SELECT 
    id, 
    RANK() OVER (
     PARTITION BY board_list_id ORDER BY 'updated_at' ASC 
    ) AS rank, 
    COUNT(id) OVER (PARTITION BY board_list_id) AS count 
    FROM buyers 
) RankedRecords 
WHERE buyers.id = RankedRecords.id 

與同board_list_id所有記錄得到他們weight更新爲相同的值。雖然我預計所有weight值都會有所不同,並取決於排名。
只運行子查詢會產生正確的結果(每個記錄具有不同的等級)。但更新不能按預期工作。
我應該改變什麼?

+0

你可以張貼buyers'的'結構(只相關列)和一些樣本數據? – joanolo

+1

刪除''updated_at''中的引號。 – klin

回答

1

在查詢中有一個非常微妙的錯誤。試試這個:

UPDATE 
    buyers 
SET 
    weight = RankedRecords.rank/(RankedRecords.count + 1.0) 
FROM 
(
    SELECT 
     id, 
     rank() OVER (PARTITION BY board_list_id ORDER BY updated_at ASC) AS rank, 
     count(id) OVER (PARTITION BY board_list_id) AS count 
    FROM buyers 
) RankedRecords 
WHERE 
    buyers.id = RankedRecords.id ; 

你的痘痘錯誤:ORDER BY 'updated_at'只是ORDER BY 'constant-text'。如果要參考該列,請使用"updated_at"(與引號)或updated_at(沒有它們,因爲您的列的名稱只是ASCII小寫字符)。

與嘗試:

CREATE TABLE buyers 
(
    id integer not null primary key, 
    board_list_id integer not null, 
    updated_at timestamp not null default now(), 
    weight double precision 
) ; 
INSERT INTO buyers (id, board_list_id, updated_at) 
VALUES 
    (1, 1, '2017-01-09'), 
    (2, 1, '2017-01-10'), 
    (3, 1, '2017-01-11'), 
    (4, 1, '2017-01-12'), 
    (5, 2, '2017-01-09'), 
    (6, 2, '2017-01-10'), 
    (7, 2, '2017-01-11'), 
    (8, 1, '2017-01-12') ; 

以前更新的結果(與一名選舉*子句)將是:

|----+---------------+---------------------+--------+----+------+-------| 
| id | board_list_id |  updated_at  | weight | id | rank | count | 
|----+---------------+---------------------+--------+----+------+-------| 
| 1 |  1  | 2017-01-09 00:00:00 | 0.1667 | 1 | 1 | 5 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 2 |  1  | 2017-01-10 00:00:00 | 0.3333 | 2 | 2 | 5 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 3 |  1  | 2017-01-11 00:00:00 | 0.5 | 3 | 3 | 5 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 8 |  1  | 2017-01-12 00:00:00 | 0.6667 | 8 | 4 | 5 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 4 |  1  | 2017-01-12 00:00:00 | 0.6667 | 4 | 4 | 5 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 5 |  2  | 2017-01-09 00:00:00 | 0.25 | 5 | 1 | 3 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 6 |  2  | 2017-01-10 00:00:00 | 0.5 | 6 | 2 | 3 | 
|----+---------------+---------------------+--------+----+------+-------| 
| 7 |  2  | 2017-01-11 00:00:00 | 0.75 | 7 | 3 | 3 | 
|----+---------------+---------------------+--------+----+------+-------| 
+0

謝謝,這工作! – leemour

相關問題