微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

添加一列,该列可以被另一列的10整除

如何解决添加一列,该列可以被另一列的10整除

称为test的表具有列:

person_id(唯一)和special_num

表格:

Table view

结果:

outcome

想创建一个名为div的新列,以确定哪个人获得的special_num可以被10整除,而哪个人不是true还是false则希望是或否。

我是MysqL的新手,从没尝试过,但是给了我一个机会,请告诉我如何获得它:

SELECT * FROM test WHERE special_num % 10 = 0 AS div from test;

我无法弄清楚如何输入值以及这是否是正确的方法

解决方法

如果您要使用,则它会放在select中:

select t.*,( (special_num % 10) = 0) as div
from t;
,

您需要一个CASE表达式:

SELECT *,CASE WHEN special_num % 10 = 0 THEN 'Yes' ELSE 'No' END AS `div`
FROM test 
,

这里是my SQLFiddle来模仿这个问题。

第一步是通过更改表来创建新列。

ALTER TABLE PERSONS 
     ADD is_special VARCHAR(3);

现在运行UPDATE查询,以检查special_num % 10是否为零,如果为零,则将is_special设置为yes

UPDATE PERSONS SET is_special = CASE WHEN special_num % 10 = 0 THEN 'yes' ELSE 'no' END;

话虽如此,存储从其他字段得出或计算的值是一个坏主意。您可能要在视图中而不是表中使用它。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。