Java Web编程的主要组件技术——JDBC

参考书籍:《J2EE开源编程精要15讲》

JDBC(Java DataBase Connectivity)是Java Web应用程序开发的最主要API之一。当向数据库查询数据时,Java应用程序先调用JDBC API,然后JDBC API把查询语句提交给JDBC驱动器,JDBC驱动器把查询语句转化为特定数据库理解的形式,JDBC驱动器检索SQL查询的结果,并转化为Java应用程序使用的等价JDBC API类和接口。

JDBC驱动器

  JDBC软件包本身不能链接任何数据库,它只是一个API框架,需要数据库驱动程序以及其他软件包提供实施方法。

  JDBC数据库驱动程序分为以下几类:

  • JDBC-ODBC桥接驱动器:把JDBC API翻译成ODBC API,适用MS Access、MS SQL Server等数据库
  • 部分本机API的Java驱动器:有些数据库,如DB2和Informix,包含数据库厂商供应的JDBC驱动器,包含可JDBC API可直接调用的类
  • 纯Java驱动器:通过IP/TCP把Java应用程序或applet链接到数据库

  常见数据库驱动器和数据库URL(本地URL)

数据库名 数据库驱动器 数据库URL(本地)
Oracle9i  oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@localhost:1521:dbName
SQL Server 2000 com.microsoft.jdbc.sqlserver.SQLServerDriver jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=ddbName;
MySQL com.mysql.jdbc.Driver jdbc:mysql://localhost/dbName
JDBC-ODBC sun.jdbc.odbc.JdbcOdbcDriver jdbc:odbc:datasourceName

JDBC API的核心组件

  • DriverManager类:用于跟踪可用的JDBC驱动程序并生成数据库连接
  • Connection接口:用于取得数据库信息,生成数据库语句,管理数据库事务
  • ResultSet接口:访问SQL查询返回的数据。next()以此定位每一行数据,用相应的get方法读取数据
  • Statement接口:提供在基层连接上运行的SQL语句,生成结果集。有2个子接口,PreparedStatement和CallableStatement   

    PreparedStatement 提供可以与查询信息一起预编译的一种语句类型

  CallableStatement继承自PreparedStatement ,用来封装数据库中存储过程的执行

用JDBC查询数据库

  • 装载驱动器
  • 连接数据库
  • 查询数据库  

  装载驱动器

    调用Class类的forName()方法装入数据库特定的驱动器,如:装载MySQL的驱动器

      Class.forName("com.mysql.jdbc.Driver");

  连接数据库

    先从DriverManager类生成Connection对象,如

      String url="jdbc:mysql://localhost/mydatabase";

      Connection con=DriverManager.getConnection(url,"Bill","123");

      本地MySQL数据库mydatabase,用户名为Bill,密码为123

  查询数据库

    1) Statement对象:把简单查询语句发送到数据库

      executeQuery()方法执行简单的选择(SELECT)查询,返回ResultSet对象

      executeUpdate()方法执行SQL的INSERT、UPDATE或DELETE语句,返回int值,给出收影响的行数

      如:

        Statement st=con.createStatement();

        ResultSet rs=st.executeQuery("select * from students");

    2) PreparedStatement对象:允许执行参数化的查询

      如:

        String sql="select * from students where stuID=?";

        PreparedStatement ps=con.prepareStatement(sql);

        ps.setString(1,"56789");//设定第一个问号处参数值为56789,类型为String

        ResultSet rs=ps.executeQuery();

    示例:

 1 import java.sql.*;
 2
 3 class Jdbc Test{
 4     public static void main(String args[]){
 5         try{
 6             Class.forName("com.mysql.jdbc.Driver");
 7             String url="jdbc:mysql://localhost/mydatabase";
 8             Connection con=DriverManager.getConnection(url,"Bill","123");
 9             String sql="select * from students where stuID=?";
10             PreparedStatement ps=con.prepareStatement(sql);
11             ps.setString(1,"56789");
12             ResultSet rs=ps.executeQuery();
13             while(rs.next()){
14                 String name=rs.getString("student_name");
15             }
16             rs.close();
17             con.close();
18         }catch(SQLException e){
19             e.printStackTrace();
20         }
21     }
22 }

    

  

时间: 2024-12-26 06:32:15

Java Web编程的主要组件技术——JDBC的相关文章

Java Web编程的主要组件技术——MVC设计模式

参考书籍:<J2EE开源编程精要15讲> MVC(Model View Controller),Model(模型)表示业务逻辑层,View(视图)代表表述层,Controller(控制)表示控制层. 在Java Web应用程序中, View部分一般用JSP和HTML构建.客户在View部分提交请求,在业务逻辑层处理后,把结果返回给View部分显示 Controller部分一般用Servlet组成,把用户的请求发给适当的业务逻辑组件处理:处理后又返回Controller,把结果转发给适当的Vie

Java Web编程的主要组件技术——Struts入门

参考书籍:<J2EE开源编程精要15讲> Struts是一个开源的Java Web框架,很好地实现了MVC设计模式.通过一个配置文件,把各个层面的应用组件联系起来,使组件在程序层面联系较少,耦合度较低.它定义了自己的标签库来实现是视图层,创建了一个内在的Servlet,叫ActionServlet,作为自己的控制器,建立一个叫Action类的对象实现业务逻辑.视图组件和业务逻辑组件的关系在struts-config.xml的配置文件中声明.当Struts应用程序启动时,它首先从struts-c

Java Web编程的主要组件技术——Hibernate核心组件

参考书籍:<J2EE开源编程精要15讲> Hibernate配置文件 1) hibernate.cfg.xml 1 <?xml version='1.0' encoding='UTF-8'?> 2 <!DOCTYPE hibernate-configuration PUBLIC 3 "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 4 "http://www.hibernate.org/dtd/

Java Web编程的主要组件技术——Struts核心组件

参考书籍:<J2EE开源编程精要15讲> Struts配置文件struts-config.xml Struts核心文件,可配置各种组件,包括Form Beans.Actions.ActionMappings.全局转发GlobalForwards.数据源DataSource及插件Plugins. 1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE struts-config PUBLI

Java Web编程的主要组件技术——Servlet

参考书籍:<J2EE开源编程精要15讲> Servlet是可以处理客户端传来的HTTP请求,并返回响应,由服务器端调用执行,有一定编写规范的Java类. 例如: 1 package test; 2 3 import java.io.IOException; 4 import java.io.PrintWriter; 5 6 import javax.servlet.ServletException; 7 import javax.servlet.http.HttpServlet; 8 impo

Java Web编程的主要组件技术——Hibernate入门

参考书籍:<J2EE开源编程精要15讲> Hibernate是对象/关系映射(ORM,Object/Relational Mapping)的解决方案,就是将Java对象与对象关系映射到关系型数据库中的表格与表格之间的关系.它是Java应用与关系数据库之间的桥梁,负责Java对象和关系数据之间的映射.Hibernate内部封装了通过JDBC访问数据库的操作,向上层应用提供了面向对象的数据库访问API. Hibernate的体系结构 Hibernate通过配置文件( hibernate.prope

Java Web编程的主要组件技术——Struts的高级功能

参考书籍:<J2EE开源编程精要15讲> Struts对国际化的支持 "国际化"(I18N)指一个应用程序在运行时能根据客户端请求所来的国家/地区.语言的不同显示不同的用户界面.要用Struts实现国际化,所要用的各种语言版本的"标签"信息存放在不同的属性文件中,每个文件对应一个语言版本.文件名后缀必须为properties,前缀名由开发者确定,其中的语言种类字段必须是有效的ISO(International Standardization Organi

JAVA web编程经验之: 一个请求一个事务

对于一个web请求,你会开启几个事务呢? 或许你没注意过吧. 又或许你不会对代码,性能要求太高,所以.... 一个请求一个事务, 因为一个事务往往和一个数据库连接关联, 如果开启了多个事务的话,也就意味着多个数据库连接, 性能不高吧? 前提 1.项目的代码结构分层如下: web层 ->  service层 -> infrastructure层(或DAO层) 2.所有事务都添加在 service层, 通过AOP(或其他类似的技术)实现 先看代码(一个Spring Controller 的调用代码

java web学习:三大组件 Listener基础

1.概念 事件源:被监听的对象 .监听器主要监听三个域对象 ,分别是 request  session  servletContext 监听器:用来监听某个对象状态变化的组件 响应行为:监听器监听的对象相应的状态发生变化时出发的动作. 2.Listener分类 在java web中,监听器的种类比较多,可以按照事件源(监听的对象)进行分类,也可以按照监听的动作进行分类.这里按照监听的动作进行分类. (1)监听域对象自身创建和销毁的监听器: ①ServletContextListener接口 监听