使用JDBC连接数据库

开发 后端
本文向您介绍使用JDBC连接数据库的一些知识,包括数据库连接的一些基本概念,结合一个JDBC连接数据库的实例,知道您建立自己的JDBC连接。

据估算,将近一半的软件开发都要涉及客户(机)/服务器方面的操作。Java为自己保证的一项出色能力就是构建与平台无关的客户机/服务器数据库应用。在Java 1.1中,这一保证通过Java数据库连接(JDBC)实现了。

数据库最主要的一个问题就是各家公司之间的规格大战。确实存在一种“标准”数据库语言,即“结构查询语言”(SQL-92),但通常都必须确切知道自己要和哪家数据库公司打交道,否则极易出问题,尽管存在所谓的“标准”。JDBC是面向“与平台无关”设计的,所以在编程的时候不必关心自己要使用的是什么数据库产品,只要使用JDBC连接数据库就可以。然而,从JDBC里仍有可能发出对某些数据库公司专用功能的调用,所以仍然不可任性妄为。
 
和Java中的许多API一样,JDBC也做到了尽量的简化。我们发出的方法调用对应于从数据库收集数据时想当然的做法:使用JDBC连接数据库,创建一个语句并执行查询,然后处理结果集。

 为实现这一“与平台无关”的特点,JDBC为我们提供了一个“驱动程序管理器”,它能动态维护数据库查询所需的所有驱动程序对象。所以假如要连接由三家公司开发的不同种类的数据库,就需要三个单独的驱动程序对象。驱动程序对象会在装载时由“驱动程序管理器”自动注册,并可用Class.forName()强行装载。

为打开一个数据库,必须创建一个“数据库URL”,它要指定下述三方面的内容:

(1) 用“jdbc”指出要使用JDBC。

(2) “子协议”:驱动程序的名字或者一种数据库连接机制的名称。由于JDBC的设计从ODBC吸收了许多灵感,所以可以选用的***种子协议就是“jdbc-odbc桥”,它用“odbc”关键字即可指定。

(3) 数据库标识符:随使用的数据库驱动程序的不同而变化,但一般都提供了一个比较符合逻辑的名称,由数据库管理软件映射(对应)到保存了数据表的一个物理目录。为使自己的数据库标识符具有任何含义,必须用自己的数据库管理软件为自己喜欢的名字注册(注册的具体过程又随运行平台的不同而变化)。

所有这些信息都统一编译到一个字串里,即“数据库URL”。举个例子来说,若想通过ODBC子协议同一个标识为“people”的数据库连接,相应的数据库URL可设为:

String dbUrl = \"jdbc:odbc:people\"

如果通过一个网络连接,数据库URL也需要包含对远程机器进行标识的信息。

准备好同数据库连接后,可调用静态方法DriverManager.getConnection(),将数据库的URL以及进入那个数据库所需的用户名密码传递给它。得到的返回结果是一个Connection对象,利用它即可查询和操纵数据库。

下面是一个使用JDBC连接数据库的例子,将打开一个联络信息数据库,并根据命令行提供的参数查询一个人的姓(Last Name)。它只选择那些有E-mail地址的人的名字,然后列印出符合查询条件的所有人:

//: Lookup.java   
// Looks up email addresses in a    
// local database using JDBC   
import java.sql.*;   
 
public class Lookup {   
  public static void main(String[] args) {   
    String dbUrl = \"jdbc:odbc:people\";   
    String user = \"\";   
    String password = \"\"; [Page]  
    try {   
      // Load the driver (registers itself)   
      Class.forName(   
        \"sun.jdbc.odbc.JdbcOdbcDriver\");   
      Connection c = DriverManager.getConnection(   
        dbUrl, user, password);   
      Statement s = c.createStatement();   
      // SQL code:   
      ResultSet r =    
        s.executeQuery(   
          \"SELECT FIRST, LAST, EMAIL \" +   
          \"FROM people.csv people \" +   
          \"WHERE \" +   
          \"(LAST=’\" + args[0] + \"’) \" +   
          \" AND (EMAIL Is Not Null) \" +   
          \"ORDER BY FIRST\");   
      while(r.next()) {   
        // Capitalization doesn’t matter:   
        System.out.println(   
          r.getString(\"Last\") + \", \"    
          + r.getString(\"fIRST\")   
          + \": \" + r.getString(\"EMAIL\") );   
      }   
      s.close(); // Also closes ResultSet   
    } catch(Exception e) {   
      e.printStackTrace();   
    }   
  }   
///:~  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.

可以看到,数据库URL的创建过程与我们前面讲述的完全一样。在该例中,数据库未设密码保护,所以用户名和密码都是空串。

用DriverManager.getConnection()建好连接后,接下来可根据结果Connection对象创建一个Statement(语句)对象,这是用createStatement()方法实现的。根据结果Statement,我们可调用executeQuery(),向其传递包含了SQL-92标准SQL语句的一个字串(不久就会看到如何自动创建这类语句,所以没必要在这里知道关于SQL更多的东西)。

executeQuery()方法会返回一个ResultSet(结果集)对象,它与继承器非常相似:next()方法将继承器移至语句中的下一条记录;如果已抵达结果集的末尾,则返回null。我们肯定能从executeQuery()返回一个ResultSet对象,即使查询结果是个空集(也就是说,不会产生一个违例)。注意在试图读取任何记录数据之前,都必须调用一次next()。若结果集为空,那么对next()的这个***调用就会返回false。对于结果集中的每条记录,都可将字段名作为字串使用(当然还有其他方法),从而选择不同的字段。另外要注意的是字段名的大小写是无关紧要的——SQL数据库不在乎这个问题。为决定返回的类型,可调用getString(),getFloat()等等。到这个时候,我们已经用Java的原始格式得到了自己的数据库数据,这样一个过程下来就完成了JDBC连接数据库的任务;接下去可用Java代码做自己想做的任何事情了。

 

【编辑推荐】

  1. JDBC数据库驱动程序种类及选择
  2. JDBC与ODBC的区别与应用
  3. JSP开发中JDBC设计加快数据库访问
  4. 浅谈JSP与JDBC的灵活运用
  5. JDBC驱动设置浅析
责任编辑:佚名 来源: 中国自学编程网
相关推荐

2009-07-14 17:18:23

JDBC怎么连接数据库

2009-07-20 15:56:08

JDBC连接数据库步骤

2009-07-20 14:30:38

jdbc连接数据库代码

2011-03-16 17:14:17

JavaBean数据库

2009-07-07 17:42:28

2012-03-02 10:51:06

JavaJDBC

2009-06-15 15:26:00

NetBeans连接数使用JSTL

2009-07-14 18:13:36

Microsoft J

2011-12-05 10:43:54

JavaJDBC数据库

2010-03-04 17:19:40

2009-03-19 10:08:09

C#数据库查询

2011-05-26 13:54:42

数据库JDBC连接

2011-05-26 09:27:59

JDBC连接数据库

2009-06-19 10:28:00

JDBC连接数据库

2011-07-05 09:54:04

2010-10-12 12:00:42

MySQL连接

2010-06-04 09:33:28

连接MySQL数据库

2010-08-04 10:32:56

Flex连接数据库

2009-08-25 14:05:06

C#连接数据库代码

2009-12-31 10:38:10

ADO.NET连接数据
点赞
收藏

51CTO技术栈公众号