我有一个表事务,列(id,金额)所有正整数,我有另一个表退款相同的列,但这里的金额预计为负数 . 现在我想使用Insert into命令从交易中选择并插入退款 . 如何在插入时使金额为负数 . 以下是我正在尝试的查询 .
INSERT INTO refund (id,amount) SELECT id, amount FROM `transaction`
有没有什么方法退款 . 默认情况下,总是需要-ve值 .
INSERT INTO refund (id,amount) SELECT id, (amount * -1) AS amount FROM `transaction`
如果您出于某种原因无法保证每次插入新行时都获得正数,请取绝对值并将其乘以-1
INSERT INTO refund (id,amount) SELECT id, -1 * ABS(amount) FROM `transaction`
否则,不需要 ABS() 部分
ABS()
INSERT INTO refund (id,amount) SELECT id, -1 * amount FROM `transaction`
只需将它乘以-1,就可以将其作为insert语句的一部分 .
INSERT INTO refund (id,amount) SELECT id, amount * -1 FROM `transaction`
INSERT INTO refund (id,amount) SELECT id, (0 - amount) as amount FROM `transaction`
因为 transaction 中的所有数据都是正数 .
transaction
INSERT INTO refund (id,amount) SELECT id, (-1 * amount) as amount FROM `transaction`
4 回答
如果您出于某种原因无法保证每次插入新行时都获得正数,请取绝对值并将其乘以-1
否则,不需要
ABS()
部分只需将它乘以-1,就可以将其作为insert语句的一部分 .
因为
transaction
中的所有数据都是正数 .