1

我目前正在尝试在我的 JSP 页面上使用 Google Charts。我正在尝试将 sql 语句的结果返回到 arraylist,我想从中获取来自 arrayList 的信息并使用它来填充谷歌图表。

<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.PreparedStatement"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.sql.SQLException"%>
<%@page import="java.util.ArrayList"%>
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<%!public static String[] getLiveData() throws SQLException, ClassNotFoundException{
    ArrayList<String> a = new ArrayList<String>();

    Class.forName("com.mysql.jdbc.Driver");
    Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/project","root", "nbuser");
    PreparedStatement ps = con.prepareStatement("SELECT department, projectname, priority, cores, disk_space FROM project.booking GROUP BY department");
    ResultSet rs = ps.executeQuery();

    while(rs.next())
    {
        a.add(rs.getString(1));
        a.add(rs.getString(4));
    }

    return (String[]) a.toArray(new String[a.size()]);
}%>
<html>
  <head>
    <script type="text/javascript" src="https://www.google.com/jsapi"></script>
    <script type="text/javascript">
      google.load("visualization", "1", {packages:["corechart"]});
      google.setOnLoadCallback(drawChart);
      function drawChart() {
        var data = google.visualization.arrayToDataTable([ISSUE TO RETURN HERE]);


        var options = {
          title: 'Company Performance'
        };

        var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
        chart.draw(data, options);
      }
    </script>

  </head>

继续在正文中调用图形等

老实说,我觉得我走错了路,但我不确定如何在我的 jsp 页面上获取数组中的数据并将其返回以创建图表。

我对java不是很好,所以如果这种方法完全关闭,我很抱歉,任何帮助都将不胜感激。

编辑

    <head>
        <script type="text/javascript">

            var theData = [ // Start of JavaScript data object
            <%
                Class.forName("com.mysql.jdbc.Driver");
                Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/project", "root", "nbuser");
                PreparedStatement ps = con.prepareStatement("SELECT department,SUM(cores) FROM project.booking GROUP BY department;");
                ResultSet rs = ps.executeQuery();

                while (rs.next()) {
            %>
                    [" <%= rs.getString(1)%>",<%= rs.getInt(2)%>],
            <%
                };
                // End of JavaScript object holding the data
            %>
                ];
        </script>

        <script type="text/javascript" src="https://www.google.com/jsapi"></script>
        <script type="text/javascript">
            google.load("visualization", "1", {packages:["corechart"]});
            google.setOnLoadCallback(drawChart);
           function drawChart() {
                var data = google.visualization.arrayToDataTable([['Department', 'Cores']].concat(theData), false);

                var options = {
                    title: 'Initial graph test'
                };
                var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
                chart.draw(data, options);
            }
        </script>

    </head>
    <body>
        <div id="chart_div" style="width: 900px; height: 500px;"></div>
        <a href="/ProjectAndBackend/System?action=livecharts">Live Charts</a>
    </body>
</html>

用户查看的最终固定实现

4

1 回答 1

1

是的,你的做法是错误的。您必须调用 Java 来获取数组的值并找到将其写入网页的方法,以便某些 javascript 可以读取它并传递给 Google Charts。

例如,HTML 可能需要如下所示:

<html>
<head>
<script type="text/javascript">

var theData = {
    {"name1",1}, // <-- write this line with JSP below
    {"name2",2}, // <-- write this line with JSP below
};
</script>
</head>

网页的其余部分以此类推。

因此,您必须生成一些 JSP 代码来执行该操作,看起来像这样。我假设您的 Java 正确地执行了 JDBC 的工作。请注意,我们有 HTML,然后我们为逻辑添加脚本,然后返回到 HTML,但有 JSP 表达式在 HTML 部分中输出数据。(当我说 HTML 时,它确实是一个用词不当,因为它输出 JavaScript,但让我有些懈怠......)

    <html>
    <head>
    <script type="text/javascript">

    var theData = [ // Start of JavaScript data object
<% 
 Class.forName("com.mysql.jdbc.Driver");
    Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/project","root", "nbuser");
    PreparedStatement ps = con.prepareStatement("SELECT department, projectname, priority, cores, disk_space FROM project.booking GROUP BY department");
    ResultSet rs = ps.executeQuery();

    while(rs.next())
    {
      ['Department', 'Cores'],
%>
      [" <%= rs.getString(1) %>", "<%= rs.getString(4)) %>"],
<%
    ]; // End of JavaScript object holding the data
%>
    };
    </script>
    </head>

这样做会得到一个保存数据的 javascript 对象。您将需要安排该对象的内容,但是您需要数据。这里有更多关于如何做到这一点的信息https://developers.google.com/chart/interactive/docs/datatables_dataviews

阅读底部的部分,其中有几个 JavaScript 对象的示例,这些示例已格式化以显示以及正确调用 Google 图表的 JavaScript 代码。

编辑

我在上面的代码中添加了标题,这样您就不必将它们连接到位。首先将它们放在 JavaScript 代码中以初始化数据对象。如果您查看此答案的历史记录,您可以看到我更改了哪一行。要使用它,请删除新代码concat中将标题放在前面的部分。

于 2013-04-04T19:04:51.477 回答