INSERT INTO..SELECT..ON DUPLICATE KEYS неоднозначные идентификаторы - PullRequest
2 голосов
/ 09 августа 2009

У меня есть следующая таблица:

mysql> SELECT *  FROM  `bright_promotion_earnings`;
+----+----------+------------+----------+-------+
| id | promoter | generation | turnover | payed |
+----+----------+------------+----------+-------+
|  1 |        4 |          1 |       10 |     0 | 
|  3 |        4 |          5 |      100 |     0 | 
|  4 |        4 |          3 |    10000 |     1 | 
|  5 |        4 |          3 |      200 |     0 | 
+----+----------+------------+----------+-------+
4 rows in set (0.00 sec)

Существует один уникальный ключ (промоутер, поколение, оплачено):

+---------------------------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+
| Table                     | Non_unique | Key_name   | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment |
+---------------------------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+
| bright_promotion_earnings |          0 | promoter_2 |            1 | promoter    | A         |           2 |     NULL | NULL   | YES  | BTREE      |         | 
| bright_promotion_earnings |          0 | promoter_2 |            2 | generation  | A         |           4 |     NULL | NULL   |      | BTREE      |         | 
| bright_promotion_earnings |          0 | promoter_2 |            3 | payed       | A         |           4 |     NULL | NULL   |      | BTREE      |         | 
+---------------------------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+
3 rows in set (0.00 sec)

Теперь я хочу отметить каждый заработок для промоутера как оплаченный, обновив ту же запись с оплаченной = 1 (если она существует).

Итак, если я хочу отметить заработок промоутера 4 как оплаченный, вот как должна выглядеть таблица:

+----+----------+------------+----------+-------+
| id | promoter | generation | turnover | payed |
+----+----------+------------+----------+-------+
|  4 |        4 |          3 |    10200 |     1 | 
|  6 |        4 |          5 |      100 |     1 | 
|  7 |        4 |          1 |       10 |     1 | 
+----+----------+------------+----------+-------+
3 rows in set (0.00 sec)

Это мой текущий подход (без УДАЛЕНИЯ, который тривиален):

INSERT INTO 
    bright_promotion_earnings
    (
        promoter,
        generation,
        turnover,
        payed
    )
SELECT 
    commission.promoter,
    commission.generation,
    commission.turnover as turnover2,
    '1' as payed
FROM  
    bright_promotion_earnings as commission
WHERE  
    promoter=4
    AND payed=0
ON DUPLICATE KEY UPDATE turnover=turnover+turnover2;

Но mysql постоянно говорит мне, что оборот неоднозначен:

#1052 - Column 'turnover' in field list is ambiguous

У кого-нибудь есть подсказка, поскольку я не могу присвоить псевдоним таблице, в которую вставляю.

Как мне дать таблицу, которую я вставляю, названию, чтобы mysql мог идентифицировать столбец?

Заранее спасибо.

1 Ответ

5 голосов
/ 09 августа 2009

у вас есть поле оборота в обеих таблицах, поэтому mysql не может решить, какое вы имеете в виду в последнем ряду.

...