2

私は次の表を持っています:

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)

1つの一意のキー(プロモーター、世代、有料)があります:

+---------------------------+------------+------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+
| 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)

ここで、同じエントリをpayed = 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)

これは私の現在のアプローチです(些細なDELETEなしで):

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が列を識別できるように、挿入するテーブルに名前を付けるにはどうすればよいですか?

前もって感謝します。

4

1 に答える 1

4

両方のテーブルにターンオーバーフィールドがあるため、mysqlは最後の行でどちらを意味するかを決定できません。

于 2009-08-09T11:02:12.580 に答える