从服务器端促进程序快速开发的Java Server Pages (JSP)决定它成为一种广为流行的工具虽然呆板的一面仍然存在然而无论它包含多少缺点JSP能够为Web程序设计者提供很多东西尤其是与数据库的输入和输出操作与数据的处理
通过JSP来进行数据库访问不需要太多的引导问题是如何使开发者能够接受Web程序的数据库访问比传统的本地OLAP系统的数据库访问更加具有吸引力并且使他们认识到整洁和简要的数据访问方法才是关键的在这一点上JSP可以很好地解决
你能够做哪些?
如果你正在编写高数据量数据密度大的Web程序时你的数据库访问应该具备哪一方面的要求?如果你正在使用JSP那么你必须处理大量的服务器端的数据程序也许需要大量的数据或者很多用户或者这二者的结合你所考虑的可能范围还会包括性能的优化可检测性每一用户的多个查询的影响查询的复杂性以及当单一的会话处理大量数据时高等级的类型转换
这其中包含大规模的处理但是JSP能够帮助你很好地处理因为它能够与Java Database Connectivity API (JDBC)很好的兼容你可以将JDBC包含在JSP代码中并且JDBC能够传递声明执行类似数据库的命令只要你能够正确地使用JDBC驱动程序
开始
这里是一个通常的抽象的JSP程序执行的体系首选的JSP设计模式为模型视图控制器(MVCModelViewController)即传统三层体系的一种变异以更好的适合于服务器程序在JSP的MVC设计模式中Model指的是程序的逻辑与数据View为查看以及Controller为请求处理
当你设计一个JSP程序时在客户端与服务器交互之间建立第一步骤的页面这是最好的一个过程例如在一个典型程序中在数据交换中的每一个特定步骤都会有页面一个数据入口页面一个验证请求页面一个数据库响应页面以及这些页面的子页面(一个更改记录的页面一个删除记录的页面等等)
你可以将JDBC嵌入到每一页面中以完成被请求的数据库操作然而这一操作也会冒很大的风险因为由于混合了JSP和JDBC而混合了整个程序──JDBC是基于SQL这也就是SQL被封装在JDBC而JDBC也被封装在JSP──这也足够让你晕头转向的如果你选择这一方法你将会获得你想要的功能但一定要保证你的程序逻辑与数据库访问代码的关系非常清晰这一点格外小心
嵌入式JDBC
JDBC API不会直接地与数据库进行交流其中的驱动程序完成的实际的连接你可以在卖方的Web站点上下载这些驱动程序除此之外还有四种JDBC的驱动程序类型如果你决定使用JDBC你需要正确地选择最为适合你需要的那种类型你将使用一个DriverManager类来处理基于驱动程序的连接
你可以使用一个名为getConnection的DriverManager方法来建立你的数据库连接你还可以使用它的URL参数来识别数据库
public static Connection getConnection(jdbc:odbc:nameOfDatabase)
现在告诉DriverManager有关驱动程序的信息(应该在你的classpath中)
ClassforName(“sunjdbcodbcnameOfJDBCDriver”);
你已经将数据库连接到JSP程序但你仍然不能够执行一个数据库命令解决这一点你可以在JSP代码中生成声明以建立数据库命令如下所示
public Statement createStatement(intresultSetType intresultSetConcurrency)
其中的参数能够让你控制从数据库查询得到的结果当使用第一个参数时可以在程序中看到结果;当使用第二个参数时你可以通过查询来更新数值(这是一个难以相信的功能在以后的文章中值得进一步讨论)
表A
?tag=sc#Listing
AListing A显示列举了下两种方法的复杂性
声明(Statement)就是SQ
L命令PreparedStatement就是SQL的声明你可以通过其中的参数来控制程序的过程CallableStatement是用于访问SQL存储程序你是否开始意识到如果你没有看到这些说明你是否觉得这些声明很复杂?请注意到通过调用rollback方法你可以撤除交易过程
如果你想完全使用这些数据库访问的方法你唯一遗漏的还有
ResultSetexecuteQuery(string sqlQuery)
(你可以使用executeQuery来完成以上过程你也可以使用一个executeUpdate来完成更新插入和删除)你以上的声明接口使你可以使用一些方法来执行SQL声明ResultSet所做的就是访问从查询得到的数据所以你可以在JSP程序中使用这些数据
通过将JSP程序分解成单一的功能明显的页面以及在任何给定页面中执行一个单一的数据库操作可以很大程度地简化你的数据库操作以及建立可以用于以后程序开发的页面即使你将SQL嵌入到这些页面的JDBC中
但是你还可以做更多的事情以使得你的JSP数据库访问更加整洁和容易维护在JSP代码中嵌入JDBC以及通过发送SQL命令与数据库通讯这些过程都很好但是它要求在不能增加代码复杂程度下建立通过接口的SQL命令的程序当你的SQL处理需要提高灵活性的时候你可以进一步地分离你的数据库接口代码以清洁你的JSP程序