comments | difficulty | edit_url | tags | |
---|---|---|---|---|
true |
中等 |
|
表 Variables
:
+---------------+---------+ | Column Name | Type | +---------------+---------+ | name | varchar | | value | int | +---------------+---------+ 在 SQL 中,name 是该表主键. 该表包含了存储的变量及其对应的值.
表 Expressions
:
+---------------+---------+ | Column Name | Type | +---------------+---------+ | left_operand | varchar | | operator | enum | | right_operand | varchar | +---------------+---------+ 在 SQL 中,(left_operand, operator, right_operand) 是该表主键. 该表包含了需要计算的布尔表达式. operator 是枚举类型, 取值于('<', '>', '=') left_operand 和 right_operand 的值保证存在于 Variables 表单中.
计算表 Expressions
中的布尔表达式。
返回的结果表 无顺序要求 。
结果格式如下例所示。
示例 1:
输入: 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 | +--------------+----------+---------------+ 输出: +--------------+----------+---------------+-------+ | 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 表中的每一个布尔表达式的值.
我们可以通过等值连接,将 Expressions
表中的每一行与 Variables
表中的两行进行关联,关联的条件是 left_operand = name
和 right_operand = name
,然后通过 CASE
表达式来判断布尔表达式的值。如果 operator
为 =
,则判断两个值是否相等;如果 operator
为 >
,则判断左值是否大于右值;如果 operator
为 <
,则判断左值是否小于右值。若是,那么布尔表达式的值为 true
,否则为 false
。
# Write your MySQL query statement below
SELECT
left_operand,
operator,
right_operand,
CASE
WHEN (
(operator = '=' AND v1.value = v2.value)
OR (operator = '>' AND v1.value > v2.value)
OR (operator = '<' AND v1.value < v2.value)
) THEN 'true'
ELSE 'false'
END AS value
FROM
Expressions AS e
JOIN Variables AS v1 ON e.left_operand = v1.name
JOIN Variables AS v2 ON e.right_operand = v2.name;