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()取值。