【JDBC】查询Student表

前言

  JDBC是在ODBC的基础上开发的支持Java的数据库编程接口,它已成为数据库开发者使用的标准的API。使用JDBC可以很容易地把SQL语句传送到任何一个关系型数据库中。其API包括如下接口:

java.sql.DriveManager--处理装载驱动程序,并且为创建新的数据库连接提供支持。
java.sql.Connection--完成对某一指定数据库的连接。
java.sql.Statement--代表一个特定的容器,用来对一个特定的数据库执行SQL语句。
java.sql.ResultSet--控制对一个特定语句行的存取。

  注意:我们需要先将连接mysql的jar包拷贝到tomcat的lib目录,单击下载。

数据库查询

  1. 加载JDBC驱动程序
  2. 与数据库建立连接
  3. 查询数据库操作
  4. 检索结果集

实例分析

环境:MyEclipse,MySQL
一、建立数据表

create table student(
    ID bigint auto_increment primary key,
    Sno bigint not null,
    Sname varchar(10) not null,
    Saddress varchar(20) not null
);

可自行添加几行数据,这里简单写了三行数据,如图1-1所示:

【JDBC】查询Student表_第1张图片
图1-1 数据库表

二、在MyEclipse中新建一个Web Project,这里命名为JDBCTest,并添加一个JSP文件,这里命名为SelectData,如图1-2所示:
【JDBC】查询Student表_第2张图片
图1-2 项目结构

三、在SelectData.jsp文件中编写查询数据库代码。

<body>
    <%
        //用MySQL建立的数据库名
        String url = "jdbc:mysql://127.0.0.1:3306/dbname";
        Connection conn = null;
        Statement sm = null;
        ResultSet rs = null;

        //加载驱动程序
        Class.forName("com.mysql.jdbc.Driver");
        try {
            //与数据建立连接
            conn = DriverManager.getConnection(url, "root", "jujianfei");
            //创建Statement对象,用于执行SQL语句
            sm = conn.createStatement();
            //执行一个SQL Select语句
            rs = sm.executeQuery("Select ID,Sno,Sname,Saddress from student");
    %>
    <h1>查询结果:h1>
    <table border="1">
        <tr>
            <th>IDth>
            <th>Snoth>
            <th>Snameth>
            <th>Saddressth>
        tr>
        <%
            while (rs.next()) {
        %>
        <tr>
            <td><%=rs.getString("ID")%>td>
            <td><%=rs.getString("Sno")%>td>
            <td><%=rs.getString("Sname")%>td>
            <td><%=rs.getString("Saddress")%>td>
        tr>
        <%
            }
                //关闭结果集和Statement对象
                rs.close();
                sm.close();
                //关闭连接
                conn.close();
            } catch (SQLException e) {
        %>
        <h2>连接数据库出错!h2>
    table>
    <%
        }
    %>
body>

  说明:这是用纯JSP的开发方式写的,应该算的上是最基础的JavaWeb。虽然看起来很多代码,不过核心的代码也就下面的几句。当然,除了查询,你也可以通过Statement的其他方法进行数据库更新操作;通过ResultSet对象的其他方法变换获取数据的方式。

//数据库地址
String url = "jdbc:mysql://127.0.0.1:3306/dbname";

//1、加载驱动程序
Class.forName("com.mysql.jdbc.Driver");
//2、与数据库建立连接
Connection conn = DriverManager.getConnection(url, "root", "jujianfei");
//创建Statement对象,用于执行SQL语句
Statement sm = conn.createStatement();
//3、执行一个SQL Select语句,将其存入ResultSet中
ResultSet rs = sm.executeQuery("Select ID,Sno,Sname,Saddress from student");
//4、循环读取表数据
while (rs.next()) {}

  打印结果如图1-3所示:

【JDBC】查询Student表_第3张图片
图1-3 打印结果

总结

  不同的数据源,需要加载的驱动程序不同,例如加载SQL Server数据库驱动程序的方式为:
  Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
  另外,通过实例也可以了解到纯JSP代码写起来确实费劲,不过也有好处:简单。无论是引入JavaBean,还是引入一些框架(如Struts2)。它们将JavaWeb的开发变得更加解耦合、可维护,易扩展的同时,也加了一点:复杂。

你可能感兴趣的:(Java)