给定一个 salary 表,如下所示,有 m = 男性 和 f = 女性 的值。交换所有的 f 和 m 值(例如,将所有 f 值更改为 m,反之亦然)。要求只使用一个更新(Update)语句,并且没有中间的临时表。
注意,您必只能写一个 Update 语句,请不要编写任何 Select 语句。
例如:
| id | name | sex | salary | |----|------|-----|--------| | 1 | A | m | 2500 | | 2 | B | f | 1500 | | 3 | C | m | 5500 | | 4 | D | f | 500 |
运行你所编写的更新语句之后,将会得到以下表:
| id | name | sex | salary | |----|------|-----|--------| | 1 | A | f | 2500 | | 2 | B | m | 1500 | | 3 | C | f | 5500 | | 4 | D | m | 500 |
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/swap-salary
解题思路:题目已经给了提示,只能使用Update语句。题目要求交换所有 f 和 m 的值,并给了提示,可以将 f 值改为 m ,m值改为 f,就可以完成题目所说的交换所有 f 和 m的值。所以这里重点是sex的值怎么能够根据我们的条件进行修改。if()语句就可以实现这个功能。其基本语法和其他见过的if语句一样,如下:if(条件,条件为真时返回结果,条件为假时返回结果)
SQL语句:
update salary set sex=if(sex='f','m','f')