Sql select语句查询所有数据并将指定字段最大值赋值给新增字段列

实际需求就是表中现有A、B、C三个字段,要通过select查询语句在查询结果中返回一个新增字段D,且字段D的所有值都是max(A);

首先获取所有数据,也可以where过滤条件

select A,B,C from table;

然后新增一个默认数据为0的字段D:

select A,B,C,'0' as D from table;

最后修改D字段值的内容(即‘0’):

select A,B,C,(select max(A) from table) as D from table;

max()函数只会返回指定列中的最大值这一条数据,所以嵌套select进行赋值给新增的字段;

一些第三方工具似乎使用select max(A) from table 来赋值给D的时候没有返回正确的值,可以在select中使用where条件过滤来代替max()取值。

posted @ 2022-07-15 23:10  诟笑  阅读(1333)  评论(0编辑  收藏  举报