leetcode-sql-627变更性别

题目:

Salary 表:

±------------±---------+

| Column Name | Type |

±------------±---------+

| id | int |

| name | varchar |

| sex | ENUM |

| salary | int |

±------------±---------+

id 是这个表的主键(具有唯一值的列)。

sex 这一列的值是 ENUM 类型,只能从 ('m', 'f') 中取。

本表包含公司雇员的信息。

请你编写一个解决方案来交换所有的 'f' 和 'm' (即,将所有 'f' 变为 'm' ,反之亦然),仅使用 单个 update 语句 ,且不产生中间临时表。

注意,你必须仅使用一条 update 语句,且 不能 使用 select 语句。

结果如下例所示。

示例 1:

输入:

Salary 表:

±---±-----±----±-------+

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

±---±-----±----±-------+

解释:

(1, A) 和 (3, C) 从 'm' 变为 'f' 。

(2, B) 和 (4, D) 从 'f' 变为 'm' 。

解答:

sql 复制代码
update Salary set sex = (case when sex = 'm' then 'f' else 'm' end)
相关推荐
小虾米vivian2 小时前
达梦:存储过程实现多个用户之间表的授权
数据库·达梦数据库
chillxiaohan4 小时前
GO学习记录九——数据库触发器的使用+redis缓存策略
数据库·缓存·golang
l1t4 小时前
DuckDB新版rusty_sheet 插件测试
xml·数据库·rust·插件·xlsx·duckdb
白鹭5 小时前
Mysql主从同步
linux·运维·数据库·mysql
M_Reus_115 小时前
MySQL-Redo Log(重做日志)
数据库·mysql
llm大模型算法工程师weng6 小时前
mysql常见面试题
数据库·mysql
Darenm1116 小时前
SQLite数据库
数据库·sqlite
得意霄尽欢7 小时前
MySQL8.0 新特性随笔
数据库·mysql
楼田莉子7 小时前
C++算法专题学习:模拟算法
开发语言·c++·学习·算法·leetcode
assibe7 小时前
cmake基本语法结构
数据库·c++·cmake