1

此 select 语句返回 4k+ 行。在我的应用程序中占用时间的是 while 循环。仅循环就需要 2 到 4 分钟。关于如何优化它的任何想法?

不要太担心查询本身,因为它不会在查询响应上花费太多时间。

ArrayList<MembershipMemberInterestsVo> list = new ArrayList<MembershipMemberInterestsVo>();
StringBuffer sql = new StringBuffer();
            sql.append("SELECT to_char(mai.id_info) as id, ");
            sql.append("to_char(mai.field_title) as title, ");
            sql.append("to_char(mmi.member_id) as membership_id ");
            sql.append("FROM memserv_member_interests mmi, memserv_add_info mai ");
            sql.append("WHERE mmi.interests like '%-' || mai.memserv_id || '-%' ");
            sql.append("AND mai.soc_body_id = ? ");
            sql.append("UNION ");
            sql.append("SELECT to_char(mit.interest_id) as id, ");
            sql.append("to_char(mit.text) as title, ");
            sql.append("to_char(mit.member_id) as membership_id ");
            sql.append("FROM memserv_member_interest_text mit ");
            sql.append("WHERE society_id = ?");

            pstmt = conn.prepareStatement(sql.toString());
            pstmt.setString(1, societyId);
            pstmt.setString(2, societyId);

            rs = pstmt.executeQuery();

            MembershipMemberInterestsVo vo = null;
            while (rs.next()) {
                vo = new MembershipMemberInterestsVo();
                vo.setInterestId(rs.getString("id"));
                vo.setMembershipId(rs.getString("membership_id"));
                vo.setTitle(rs.getString("title"));
                vo.setSocietyId(societyId);
                list.add(vo);
            }
4

2 回答 2

5

问题很可能出在您的 SQL 语句上。将 4,000 个条目添加到列表中,不会花费任何明显的时间。

如果这不是错字

WHERE mmi.interests like '%-' || mai.memserv_id || '-%'

您最终将整个表作为结果集。

于 2013-03-25T09:55:00.783 回答
0

我猜这不是while循环,而是从数据库中检索数据的时间必须花费大量时间——这是在迭代结果集期间。

不要在 while 循环中创建任何对象,只需遍历结果集并查看所需时间。应该差不多。

于 2013-03-25T09:51:43.370 回答