如何解决添加一列,该列可以被另一列的10整除
称为test的表具有列:
person_id(唯一)和special_num
表格:
结果:
想创建一个名为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 举报,一经查实,本站将立刻删除。