select (select sc01.aab300 from sc01 where bsc001 = substr(sbk_fxqk.aab300,0,4)||'00' ) pac,sum(sdk) sdk, sum(stk) stk,sum(dzk) dzk,round(sum(stk)/sum(czrks)*100,2)||'%' stk_r,round(sum(dzk)/sum(czrks)*100,2)||'%' dzk_r from sbk_fxqk group by substr(sbk_fxqk.aab300,0,4) order by substr(aab300,0,4)帮我看下这个sql有什么问题怎么修改
时间: 2023-11-21 17:06:01 浏览: 101
这个 SQL 查询语句缺少别名,导致在 order by 语句中无法识别 aab300 字段。同时,在 select 子句中使用了子查询,如果子查询返回多行的话,将会出现错误。建议将这个子查询转换为 join 操作。
以下是修改后的 SQL 查询语句:
```
SELECT
sc01.aab300 pac,
SUM(sbk_fxqk.sdk) sdk,
SUM(sbk_fxqk.stk) stk,
SUM(sbk_fxqk.dzk) dzk,
ROUND(SUM(sbk_fxqk.stk) / SUM(sbk_fxqk.czrks) * 100, 2) || '%' stk_r,
ROUND(SUM(sbk_fxqk.dzk) / SUM(sbk_fxqk.czrks) * 100, 2) || '%' dzk_r
FROM
sbk_fxqk
JOIN sc01 ON sbk_fxqk.bsc001 = substr(sc01.aab300, 0, 4) || '00'
GROUP BY
substr(sbk_fxqk.aab300, 0, 4),
sc01.aab300
ORDER BY
sc01.aab300
```
希望能对您有所帮助!
相关问题
帮我改进一段代码 SELECT ( SELECT aab004 FROM ab01 c WHERE a.aab001 = c.aab001) aab004, a.aac002, a.aac003, (SELECT cae102 FROM aea1 d WHERE a.aac004 = d.cae101 and d.cae100 = 'AAC004')aac004, a.aac006, b.aae013, b.cae012, b.cae013, b.tcc501 FROM ac01 a, tc05 b WHERE a.aac001 = b.aac001 AND a.aac002 = #{dto.aac002},当b.acc001为空的时候也能查出来值
这段代码存在一些问题,具体如下:
1. 使用了旧式的JOIN语法,应该改为使用INNER JOIN或LEFT JOIN等现代语法。
2. 子查询中使用了多个表,可能会导致性能问题,应该尽量避免使用子查询。
3. 子查询中使用了等于号(=)和IN操作符,应该使用JOIN语法来代替。
4. 没有使用表别名,可能会导致代码可读性差。
改进后的代码如下:
SELECT aab004, aac002, aac003, cae102, aac006, aae013, cae012, cae013, tcc501
FROM ac01 a
INNER JOIN tc05 b ON a.aac001 = b.aac001
INNER JOIN ab01 c ON a.aab001 = c.aab001
LEFT JOIN aea1 d ON a.aac004 = d.cae101 AND d.cae100 = 'AAC004'
WHERE 1=1
改进后的代码使用了现代JOIN语法,避免了使用子查询,使用了JOIN语法代替等于号和IN操作符,使用了表别名,提高了代码可读性。
doSelect(){ var that=this; var maintenance=that.form.maintenance; var aab073 = that.form.aab073; var queryCondition = that.form.queryCondition; var whereCondition = "1 = 1"; let lagRegister = that.$refs['lagRegister'].getWidget(); if(isNotNull(maintenance)){ whereCondition += " and aab073 is '"+maintenance+"'"; } if(isNotNull(aab073)){ whereCondition += " and aab073 = '"+aab073+"'"; } if(isNotNull(queryCondition)){ whereCondition += " and (bab001 like '%"+queryCondition+"%' or aab004 like '%"+queryCondition+"%' or aab998 like '%"+queryCondition+"%')"; } var aae002=that.form.aae002 if(isNotNull(aae002)){ // whereCondition += " and (aab004 like '%"+queryCondition+"%' or aab361 like '%"+queryCondition+"%')"; whereCondition += " and (aae002 = '"+aae002+"')"; } lagRegister.doRefresh({ whereCondition:whereCondition}); },哪里有问题
代码中存在以下问题:
1. 缺少函数定义的函数名,这部分代码可能是函数内部的代码,需要放到函数内部。
2. `isNotNull` 函数未定义,需要先定义该函数或使用其他判断函数。
3. 变量 `aae002` 在代码中只有一个地方被使用,可以直接在判断条件中使用,不需要单独定义变量。
建议修改后的代码如下:
```
// 假设函数名为 selectData
selectData() {
var that = this;
var maintenance = that.form.maintenance;
var aab073 = that.form.aab073;
var queryCondition = that.form.queryCondition;
var whereCondition = "1 = 1";
let lagRegister = that.$refs['lagRegister'].getWidget();
if (maintenance) {
whereCondition += " and aab073 is '" + maintenance + "'";
}
if (aab073) {
whereCondition += " and aab073 = '" + aab073 + "'";
}
if (queryCondition) {
whereCondition += " and (bab001 like '%" + queryCondition + "%' or aab004 like '%" + queryCondition + "%' or aab998 like '%" + queryCondition + "%')";
}
if (that.form.aae002) {
whereCondition += " and (aae002 = '" + that.form.aae002 + "')";
}
lagRegister.doRefresh({ whereCondition: whereCondition });
}
```
阅读全文