优化mySQL语句 SELECT * (SELECT DEPT_ID, FROM SPSYS_DEPARTMENT WHERE DEPT_ABBR = COST_CENTER AND RECORD_STATUS = '1') DEPT_ID, (SELECT DEPT_NAME FROM SPSYS_DEPARTMENT WHERE DEPT_ABBR = COST_CENTER AND RECORD_STATUS = '1') DEPT_NAME, (SELECT DEPT_NO FROM SPSYS_DEPARTMENT WHERE DEPT_ABBR = COST_CENTER AND RECORD_STATUS = '1') DEPT_NO, FROM BM_BUDGET_REC_EXEC_ORA_IMP WHERE CURRENCY = 'RMB'
时间: 2024-02-14 14:15:00 浏览: 299
这个 SQL 查询语句可以进行如下优化:
1. 使用 JOIN 代替子查询,可以提高查询效率:
```
SELECT b.DEPT_ID, d.DEPT_NAME, d.DEPT_NO
FROM BM_BUDGET_REC_EXEC_ORA_IMP b
LEFT JOIN SPSYS_DEPARTMENT d ON b.COST_CENTER = d.DEPT_ABBR
WHERE b.CURRENCY = 'RMB' AND d.RECORD_STATUS = '1';
```
2. 不要使用 SELECT *,只选择需要的列,可以减少查询时间和网络传输的数据量。
```
SELECT b.DEPT_ID, d.DEPT_NAME, d.DEPT_NO
FROM BM_BUDGET_REC_EXEC_ORA_IMP b
LEFT JOIN SPSYS_DEPARTMENT d ON b.COST_CENTER = d.DEPT_ABBR
WHERE b.CURRENCY = 'RMB' AND d.RECORD_STATUS = '1';
```
3. 对于经常查询的列,可以添加索引,以提高查询效率。
```
ALTER TABLE SPSYS_DEPARTMENT ADD INDEX idx_dept_abbr_record_status (DEPT_ABBR, RECORD_STATUS);
```
相关问题
优化mysql语句SELECT PERIOD_NET_BEQ, BUDGET_MONTH, PERIOD_NET, COST_CENTER, REFERENCE, PLANE_TYPE, ROUTE, PLANE_NO, AIRPORT, ( SELECT DEPT_ID FROM BM_SYS_3.SPSYS_DEPARTMENT WHERE DEPT_ABBR = CO
可以尝试以下优化方法:
1. 添加索引:在查询涉及到的列上添加索引,特别是在 WHERE 条件和 JOIN 操作中使用的列上添加索引。例如,在 BM_SYS_3.SPSYS_DEPARTMENT 表的 DEPT_ABBR 列上添加索引。
2. 减少子查询:可以将子查询转换为 JOIN 操作,或者使用临时表将子查询的结果缓存起来,避免重复计算。例如,将 SELECT DEPT_ID FROM BM_SYS_3.SPSYS_DEPARTMENT WHERE DEPT_ABBR = CO 转换为 JOIN 操作,或者使用临时表将查询结果缓存起来。
3. 优化查询语句:尽可能使用简单的查询语句,避免使用复杂的子查询、嵌套查询等语句。可以通过分解查询、使用 UNION 操作等方式来简化查询语句。
4. 避免全表扫描:尽可能避免使用 SELECT * 等全表扫描操作,只选择需要的列。
5. 使用合适的数据类型:在创建表时,选择合适的数据类型,尽可能避免使用过大或过小的数据类型。例如,可以使用 INT 替代 VARCHAR 存储数字类型的数据。
6. 避免重复数据:在设计表结构时,避免重复数据的存储,使用关联表、枚举类型等方式来减少数据冗余。
import weaver.general.Util; import weaver.conn.RecordSet; import net.sf.json.JSONObject; /** * @Method: SimplifiedSql * @Description: 简化sql写法,在数据库中查询从1~12月的sql值 * @param month OA表单传的月份参数,是动态变量。 0对应1月 ~ 11对应12月 * @param year OA表单传的年份参数,是动态变量 * @param deptName OA表单传的部门编号参数,是动态变量。由此函数翻译成部门名称简写 * @return */ public class Main { static String month = "0"; static String year = "2023"; static String deptName = "zh"; static int Num_of_Cycles = 2; RecordSet rs = new RecordSet(); // 数据库包 JSONObject json = new JSONObject(); // public void main(String[] args) { } public JSONObject SimplifiedSql (String month, String year, String deptName,int Num_of_Cycles){ for (int i = 0; i < Num_of_Cycles; i++) { String Num2String = Integer.toString(i + 1); // 数字转字符串,用于sql中的下角标 String calculated_abbr = deptName + "_calculated" + Num2String; // 计算值变为缩写 String actual_abbr = deptName + "_actual_" + Num2String; // 实际值 String target_abbr = deptName + "_target_" + Num2String; // 目标值 String sql = ""; // 1月份 if (month.equals("0")) { sql = "select (100 + ROUND((? - ?) / (? * 0.01), 2)) as " + calculated_abbr + " from dual"; rs.executeQuery(sql, actual_abbr, target_abbr, target_abbr); } rs.next(); String calculated = Util.null2String(rs.getString(calculated_abbr)); json.put(calculated_abbr, calculated); } return json; } }
这段代码是一个Java类,包含一个名为`SimplifiedSql`的方法,该方法接受四个参数:`month`、`year`、`deptName`和`Num_of_Cycles`。该方法的作用是根据传入的参数,在数据库中查询1月至12月的计算值,并将结果存储在一个`JSONObject`对象中返回。
具体实现过程如下:
1. 通过一个循环,查询1至12个月的计算值。
2. 在循环中,将部门名称和月份转换为相应的缩写,用于后续的SQL语句中。
3. 根据传入的月份参数,构造相应的SQL语句。如果月份为0,表示查询1月份的计算值,否则查询相应月份的计算值。
4. 执行SQL语句,获取计算值。
5. 将计算值存储在一个`JSONObject`对象中,并返回该对象。
需要注意的是,该类中的`rs`和`json`对象是类成员变量,可以在不同的方法中使用。而`main`方法是Java程序的入口方法,不需要进行任何操作。
阅读全文