本文将给出一个最简单的Java查询数据库中一张表的数据并将查询结果展示在页面的例子.

实际上,我们要解决以下两个问题:

  • Java与数据库交互(以JDBC为例)
  • 数据展示在前台页面(以Servlet+JSP为例)

数据结构:

学生表(student)

student_id : 学号(主键,字符,非空)

student_name:学生姓名(字符,非空)

student_age:学生年龄(整型,非空)

附:数据库脚本和初始化数据(MySQL为例):

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for `student`
-- ----------------------------
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`student_id` varchar(255) NOT NULL,
`student_name` varchar(255) NOT NULL,
`student_age` int(11) NOT NULL,
PRIMARY KEY (`student_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES ('1', 'zhangsan', '20');
INSERT INTO `student` VALUES ('2', 'lisi', '21');
INSERT INTO `student` VALUES ('3', 'wangwu', '19');

Java与数据库交互(以JDBC为例):

import java.sql.*;

public class Main {

    static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
static final String DB_URL = "jdbc:mysql://localhost/tt"; static final String USER = "root";
static final String PASS = "root"; public static void main(String[] args) throws Exception {
Connection conn = null;
Statement stmt = null; //STEP 2: Register JDBC driver
Class.forName(JDBC_DRIVER); //STEP 3: Open a connection
conn = DriverManager.getConnection(DB_URL,USER,PASS); //STEP 4: Execute a query
stmt = conn.createStatement();
String sql;
sql = "SELECT student_id, student_name, student_age FROM student";
ResultSet rs = stmt.executeQuery(sql); //STEP 5: Extract data from result set
while(null != rs && rs.next()){ String studentId = rs.getString("student_id");
String studentName = rs.getString("student_name");
int student_age = rs.getInt("student_age"); System.out.println("student_id: " + studentId);
System.out.println("student_name: " + studentName);
System.out.println("student_age: " + student_age);
System.out.println("-----------");
} rs.close();
stmt.close();
conn.close();
}
}

需要注意:

1.运行这个程序需要下载MySQL驱动包:

http://www.mysql.com/downloads/

2.这个程序肯定可以优化,利用之前学的封装,异常处理等知识优化一下这段代码。

3.试着实现对数据库的其他操作,比如增删改。


数据展示在前台页面(以Servlet+JSP为例):

输入页面input.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>从前台到后台</title>
</head>
<body>
<form action="HandleServlet">
<input type="text" id="studentName" name="studentName"> <input
type="submit" value="submit">
</form>
</body>
</html>

新建Servlet:HandleServlet.java 配置其URL Mappings为:/HandleServlet

在其doGet方法里面写以下代码:

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String studentName = request.getParameter("studentName");
System.out.println("已经传到后台:"+studentName);
RequestDispatcher dispatcher = request.getRequestDispatcher("/output.jsp");
request.setAttribute("studentName",studentName);// 传回前台
dispatcher .forward(request, response); }

输出界面:output.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>从后台到前台</title>
</head>
<body>
欢迎:<%=request.getAttribute("studentName")%>
</body>
</html>

将程序部署到Tomcat下,启动Tomcat,访问input,并输入学生名字,点击submit按钮,则:

1.HandleServlet接收到学生名字的输入并打印在控制台。

2.HandleServlet将学生名字传到output.jsp页面并展示出来。

需要注意:

1.代码肯定还可以优化,如:JSP页面可以采用JSTL标签来获取数据。

2.Eclipse配置tomcat参考:

http://jingyan.baidu.com/article/ca2d939dd90183eb6d31ce79.html

到目前为止,将这一步和之前的与数据库连接结合起来,就可以实现页面展示在前台界面的功能,部分只实现静态页面的团队可以参考一下将自己的静态页面变为动态从数据库取数据的方式。

若能将取数据的过程发布成服务(如:webservice),也会是一个不错的方向,有想法的童鞋,可以试试看。

【助教】Java获取数据库数据展示的更多相关文章

  1. java获取数据库数据表的元数据

    Connction conn; DatabaseMetaData dmd=conn.getMetaData();//获取数据库元数据 PreparedStatment ps; ps.getParame ...

  2. 【java 获取数据库信息】获取MySQL或其他数据库的详细信息

    1.首先是 通过数据库获取数据表的详细列信息 package com.sxd.mysqlInfo.test; import java.sql.Connection; import java.sql.D ...

  3. jmeter 性能测试 JDBC Request (查询数据库获取数据库数据) 的使用

    JDBC Request 这个Sampler可以向数据库发送一个jdbc请求(sql语句),并获取返回的数据库数据进行操作.它经常需要和JDBC Connection Configuration配置原 ...

  4. jmeter JDBC Request (查询数据库获取数据库数据) 的使用

    JDBC Request 这个Sampler可以向数据库发送一个jdbc请求(sql语句),并获取返回的数据库数据进行操作.它经常需要和JDBC Connection Configuration配置原 ...

  5. 转jmeter 性能测试 JDBC Request (查询数据库获取数据库数据) 的使用

    JDBC Request 这个Sampler可以向数据库发送一个jdbc请求(sql语句),并获取返回的数据库数据进行操作.它经常需要和JDBC Connection Configuration配置原 ...

  6. 38)PHP,获取数据库数据并在html中显示(晋级5)

    还有一个加了单例模式的,在第52个. 首先是我的文件关系: 我的主php文件是index.php,我的配置文件php是BBB.php  我的数据库操作文件是  b.php    我的html文件是lo ...

  7. 37)PHP,获取数据库数据并在html中显示(晋级4)

    我的php文件和html文件的位置关系: 然后我的主php文件是b.php,我的那个配置文件是BBB.php,我的html文件是login.html 然后我的b.php代码展示: <?php c ...

  8. 36)PHP,获取数据库数据并在html中显示(晋级3)

    首先展示我的html代码和php文件的位置关系: 然后我的php文件: <?php class db { public $host ;//= "localhost";//定义 ...

  9. [Java] Java 获取数据库所有表基本信息和表中的所有列基本信息代码

    废话不多说.上代码 import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import ...

随机推荐

  1. SVN(TortoiseSVN)提交时忽略bin跟obj目录

    SVN(TortoiseSVN)提交时忽略bin和obj目录 一般协作开发情况下,有意思无意将bin和obj目录添加到版本管理中是很烦人的事儿,在VS中不断地编译程序集和提交将带来版本暴增问题.如果你 ...

  2. mysql-5.7.15-winx64免安装版配置

    1.拷到硬盘根目录下; 2.在 bin 平行目录下新建  data 文件夹: 3. 修改  my-default.ini 文件,添加 basedir = C:\mysql-5.7.15-winx64d ...

  3. HttpURLConnection GET/POST写法

    现在虽然HttpClient很好使,但也有人在用最原生的HttpURLConnection, 记录一下,备忘之. public class HttpUrlConnect { //get请求 publi ...

  4. Linux 统计某个字符串出现的次数

    要统计一个字符串出现的次数,这里现提供自己常用两种方法: 1. 使用vim统计 用vim打开目标文件,在命令模式下,输入 :%s/objStr//gn 即可 2. 使用grep: grep -o ob ...

  5. JS区别不同浏览器(微信、手机等)

    最近一直在忙于自己公司的旅游产品,设计方面太广并且要兼容各种设备和场景,包括PC.Mobile.Pad.还有各种支付.由于微信支付和支付宝存在竞争,所以需要区别不同的浏览器,并且WEB项目还要出现在A ...

  6. App 卸载记录

    http://blog.csdn.net/jiangwei0910410003/article/details/36427963 总结:没有root权限的情况下,还是使用Intent发送卸载请求,同时 ...

  7. Python 中Editplus 特别实用的设置方法

    editplus 中输入tab自动变成4个空格打开tools->preference打开面板,files的子栏目->settings & syntax面板中的 tab/indent ...

  8. dsoframer控件学习小结(打开WORD,EXCEL等文件)

    根据自己对dsoframer控件的学习,想把dsoframer控件进行简单的包装为C#的usercontrol,大体需要作如下:(创建windows的usercontrol的步骤就不再说了...)我们 ...

  9. ODAC (V9.5.15) 学习笔记(二十)大数据量获取处理

    ODAC获取数据的效率比较高,在Web程序中希望能够更快获取第一页的数据时,可以有几种方式: 1.在数据库中进行分页处理: 2.获取所有数据,只是快速返回第一页数据. 第一种方案对应用服务器资源消耗最 ...

  10. maven eclipse jetty debug

    可以通过查看最近版本: http://mvnrepository.com/artifact/org.eclipse.jetty/jetty-server http://search.maven.org ...