前言
JDBC是在ODBC的基础上开发的支持Java的数据库编程接口,它已成为数据库开发者使用的标准的API。使用JDBC可以很容易地把SQL语句传送到任何一个关系型数据库中。其API包括如下接口:
java.sql.DriveManager--处理装载驱动程序,并且为创建新的数据库连接提供支持。
java.sql.Connection--完成对某一指定数据库的连接。
java.sql.Statement--代表一个特定的容器,用来对一个特定的数据库执行SQL语句。
java.sql.ResultSet--控制对一个特定语句行的存取。
注意:我们需要先将连接mysql的jar包拷贝到tomcat的lib目录,单击下载。
数据库查询
- 加载JDBC驱动程序
- 与数据库建立连接
- 查询数据库操作
- 检索结果集
实例分析
环境: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所示:
图1-1 数据库表
二、在MyEclipse中新建一个Web Project,这里命名为JDBCTest,并添加一个JSP文件,这里命名为SelectData,如图1-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>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所示:
图1-3 打印结果
总结
不同的数据源,需要加载的驱动程序不同,例如加载SQL Server数据库驱动程序的方式为:
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
另外,通过实例也可以了解到纯JSP代码写起来确实费劲,不过也有好处:简单。无论是引入JavaBean,还是引入一些框架(如Struts2)。它们将JavaWeb的开发变得更加解耦合、可维护,易扩展的同时,也加了一点:复杂。