所以我尝试用数据库和图表做一些基本的工作。我已经得到了JSP代码的工作,但是我想把它转到一个服务器/其他资源上,因为我听说在jsp做每件事都是一个非常糟糕的主意。我做了一些关于Starlets的研究,但我对它们如何工作/如何与jsps和其他文件连接感到非常困惑。
但我主要关心数据库连通代码。
以下是我的JSP:
<%@ page language="java" import="java.sql.*, java.util.*"%>
<html>
<head>
<title>D3 Test</title>
<script type="text/javascript" src="d3/d3.v2.js"></script>
<style type="text/css">
</style>
</head>
<body>
<%
Class.forName("com.mysql.jdbc.Driver");
Connection con=null;
ResultSet rst=null;
Statement stmt=null;
try{
String url="jdbc:mysql://localhost:3306/testdb?user=root&password=password";
int i=1;
con=DriverManager.getConnection(url);
stmt=con.createStatement();
rst=stmt.executeQuery("select * from test ");
%>
<script type="text/javascript">
var dataset = [
<% while (rst !=null && rst.next()) { %>
<%=rst.getInt("ID")%>,
<% }%>
];
var w = 500;
var h = 340;
var barPadding = 1;
/*var xScale = d3.scale.linear()
.domain([0, d3.max(dataset, function(d) { return d[0]; })])
.range([padding, w - padding * 2]);
var yScale = d3.scale.linear()
.domain([0, d3.max(dataset, function(d) { return d[1]; })])
.range([h - padding, padding]);*/
var svg = d3.select("body")
.append("svg")
.attr("width", w)
.attr("height", h);
svg.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.attr("id", "rect1")
.attr("x", function(d, i) {
return i * (w / dataset.length);
})
.attr("y", function(d) {
return h - d*4;
})
.attr("width", w/ dataset.length - barPadding)
.attr("height", function(d) {
return d * 4;
})
.attr("fill", function(d) {
return "rgb(0, 0, " + (d * 10) + ")";
});
svg.selectAll("text")
.data(dataset)
.enter()
.append("text")
.text(function(d) {
return d;
})
.attr("x", function(d, i) {
return i * (w / dataset.length)+ (75 / dataset.length);
})
.attr("y", function(d) {
return h - (d * 4) + 15;
})
.attr("font-family", "sans-serif")
.attr("font-size", "11px")
.attr("fill", "white");
<%
} finally {
if (stmt != null) { stmt.close(); }
}%>
</script>
</body>
</html>