LeetCode MySQL 1440. 计算布尔表达式的值(case when then else end)

2021-02-19 10:34:47 浏览数 (1)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

表 Variables:

代码语言:javascript复制
 --------------- --------- 
| Column Name   | Type    |
 --------------- --------- 
| name          | varchar |
| value         | int     |
 --------------- --------- 
name 是该表主键.
该表包含了存储的变量及其对应的值.

表 Expressions:

代码语言:javascript复制
 --------------- --------- 
| Column Name   | Type    |
 --------------- --------- 
| left_operand  | varchar |
| operator      | enum    |
| right_operand | varchar |
 --------------- --------- 
(left_operand, operator, right_operand) 是该表主键.
该表包含了需要计算的布尔表达式.
operator 是枚举类型, 取值于('<', '>', '=')
left_operand 和 right_operand 的值保证存在于 Variables 表单中.

写一个 SQL 查询, 以计算表 Expressions 中的布尔表达式.

返回的结果表没有顺序要求.

查询结果格式如下例所示.

代码语言:javascript复制
Variables 表:
 ------ ------- 
| name | value |
 ------ ------- 
| x    | 66    |
| y    | 77    |
 ------ ------- 

Expressions 表:
 -------------- ---------- --------------- 
| left_operand | operator | right_operand |
 -------------- ---------- --------------- 
| x            | >        | y             |
| x            | <        | y             |
| x            | =        | y             |
| y            | >        | x             |
| y            | <        | x             |
| x            | =        | x             |
 -------------- ---------- --------------- 

Result 表:
 -------------- ---------- --------------- ------- 
| left_operand | operator | right_operand | value |
 -------------- ---------- --------------- ------- 
| x            | >        | y             | false |
| x            | <        | y             | true  |
| x            | =        | y             | false |
| y            | >        | x             | true  |
| y            | <        | x             | false |
| x            | =        | x             | true  |
 -------------- ---------- --------------- ------- 
如上所示, 你需要通过使用 Variables 表
来找到 Expressions 表中的每一个布尔表达式的值.

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/evaluate-boolean-expression 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

代码语言:javascript复制
# Write your MySQL query statement below
select left_operand, operator, right_operand, 
        case when (l-r>0 and operator='>')
                or(l=r and operator='=')
                or(l-r<0 and operator='<') then 'true'
            else 'false' end
        as 'value'
from
(
    select e.left_operand, e.operator, e.right_operand,
        	v1.value l, v2.value r
    from Expressions e
    left join Variables v1
    	on e.left_operand = v1.name
    left join Variables v2
    	on e.right_operand = v2.name
) t

0 人点赞