0

我正在研究 GraphStream 显示数据库中的数据。但它创建节点和边缘的速度非常慢。我正在使用这个非常基本的示例。

这是我的代码:

public class GraphExplore {
    static Connection conn2;
    static String result, result2;
    static JFrame frame;
    static JPanel panel;
    static int totalRows, i;

    public static void main(String args[]) throws SQLException {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    showData();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        });
    }

    private static void showData() throws SQLException {

        frame = new JFrame("GRAPH TESTING");

        Graph graph = new SingleGraph("tutorial 1");
        graph.setAutoCreate(true);
        graph.setStrict(false);
        graph.display();

        try {
            Class.forName("org.h2.Driver");
            conn2 = DriverManager.getConnection("jdbc:h2:file:G:/hs_data/h2_db/test", "sa", "sa");

        } catch (Exception e) {
            e.printStackTrace();
        }
        Statement stmt2 = conn2.createStatement();
        ResultSet rs = stmt2.executeQuery("SELECT count(*) FROM cdr");
        while (rs.next()) {
            totalRows = rs.getInt(1);
        }
        ResultSet rs2 = stmt2.executeQuery("SELECT ANUMBER,BNUMBER FROM CDR LIMIT 20");
        while (rs2.next()) {
            result = rs2.getString("ANUMBER");
            result2 = rs2.getString("BNUMBER");
            graph.addNode(result);
            graph.addNode(result2);
            for (i = 0; i < totalRows; i++)
                graph.addEdge("string" + i, result, result2);
        }

        for (Node node : graph) {
            node.addAttribute("ui.label", node.getId());
        }
        // graph.addAttribute("ui.stylesheet", "graph { fill-color: red; }");text-mode:
        // hidden;
        graph.addAttribute("ui.stylesheet", "node {size: 12px;fill-color: #ff0000;z-index: 0;}");
        graph.addAttribute("ui.stylesheet", "edge { shape:line ; fill-color: #222;}");
        conn2.close();
    }

}

现在,我只使用 20 行,需要 3-4 秒。但我需要一次显示更多记录(可能超过 100 万条)。谁能告诉我如何提高渲染速度?

4

1 回答 1

0

这里只是一个疯狂的猜测。您是否尝试过专门计时 JDBC 从查询返回结果所花费的时间?我会从这里开始。如果您发现查询很快返回,则不是数据库的问题。如果是,您可以考虑使用索引来更快地返回结果。

如果查询不是问题,您可以查看图表功能。我的猜测会让我相信渲染速度很慢,因为图表设置为显示,然后将节点和边添加到其中,因此它是实时渲染的。可以在开始渲染图形之前预加载节点和边,从而减少绘图调用的数量。

于 2017-07-12T13:37:45.037 回答