前言

  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所示:



global log_bin_trust_function_creators 查询_SQL


图1-1 数据库表



二、在MyEclipse中新建一个Web Project,这里命名为JDBCTest,并添加一个JSP文件,这里命名为SelectData,如图1-2所示:




global log_bin_trust_function_creators 查询_SQL_02


图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>ID</th>
            <th>Sno</th>
            <th>Sname</th>
            <th>Saddress</th>
        </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所示:



global log_bin_trust_function_creators 查询_数据库_03


图1-3 打印结果


总结

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