Java数据库编程--JDBC

java

一、定义

JDBC,Java DataBase Connectivity。

是Java运行平台核心类库中的一部分,提供了访问数据库的API,由一些Java类和接口组成。

在Java中可以使用JDBC实现对数据库中表记录的查询,修改,和删除等操作

JDBC技术在数据库开发中占有很重要的地位。JDBC操作不同的数据库仅仅是连接方式上的差异。

使用JDBC的应用程序一旦和数据库建立连接,就可以使用JDBC提供的API操作数据库

操作步骤:

1.与一个数据库建立连接

2.向已连接的数据库发送SQL语句

3.处理SQL语句返回的结果

 

二、连接数据库

1.建立JDBC-ODBC桥接器

JDBC使用java.lang包中的Class类建立JDBC-ODBC桥接器。Class类通过调用它的静态方法forName加载sun.jdbc.odbc包中的jdbcOdbcDriver类建立JDBC-ODBC桥接器。

建立桥接器时可能发生异常,因此,必须捕获这个异常。

建立桥接器的代码:

1 try{Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

2 }

3 catch(ClassNotFoundException e){

4 System.out.println(e);

5 }

三、建立连接

在编写的连接数据库代码中不会出现数据库的名称,只能出现数据源的名字。

首先使用java.sql包中的Connection类声明一个对象,然后使用DriverManager类调用它的静态方法getConnection创建这个连接对象

1 Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","login name","passworf");

如果没有为数据源设置login name和password 那么连接形式如下:

1 1 Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","","");

为了能和数据源star交换数据,在建立链接时应捕获SQLException异常

1 try{Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","","");}

2 catch(SQLException e){}

应用程序一旦和某个数据源建立连接,就可以通过SQL语句和该数据源所指定的数据库中的表交互信息,比如增上改查。

四、示例

 

 1 package org.mobiletrain.jdbc1;

2

3 import java.sql.Connection;

4 import java.sql.DriverManager;

5 import java.sql.ResultSet;

6 import java.sql.SQLException;

7 import java.sql.Statement;

8 import java.util.ArrayList;

9 import java.util.List;

10

11 /**

12 * 本程序执行用java代码查询数据库,返回结果。存入List集合中

13 *

14 * @author Administrator

15 *

16 */

17 public class Demo01_JDBC {

18

19 public static void main(String[] args) {

20 // step1:加载驱动程序

21 /**

22 * 1.需要将数据库的驱动包(接口的实现类程序),复制到工程中:WebContent/WEB_INF/lib

23 *

24 * 2.jar包上右键build path

25 *

26 * 3.通过反射,让当前的类识别驱动程序

27 */

28 Connection conn = null;// 连接数据库的对象

29 Statement statement = null;// 传送sql语句并执行的对象

30 ResultSet rSet = null;// 存储查询结果的对象

31 try {

32 Class.forName("org.sqlite.JDBC");// 通过反射,获取驱动程序

33 // step2:提供链接的参数

34 String url = "jdbc:sqlite:/c:/pro/test.db";

35 // step3:动DriverManager中获取连接对象Connection

36 conn = DriverManager.getConnection(url);

37 // step4:准备sql语句,并且创建传送器对象

38 String sql = "select id,name,age,sex,classno from student";

39 statement = conn.createStatement();

40 // step5:传送sql语句,并执行

41 rSet = statement.executeQuery(sql);// 表示传送器传送sql语句,并执行

42 // step6:处理数据

43 List<Student> list = new ArrayList<Student>();// 创建容器,用于存储学生对象,数据来源于结果集

44 // 循环获取结果集中的数据

45 while (rSet.next()) {

46 // 需要从结果集中取数据

47 int id = rSet.getInt(1);// 获取查询到的第一列的内容

48 String name = rSet.getString("name");// 通过字段名称获取内容

49 int age = rSet.getInt("age");

50 String sex = rSet.getString("sex");

51 int classno = rSet.getInt("classno");

52 // 根据字段的数值,创建学生对象

53 Student stu = new Student(id, name, age, sex, classno);

54 // 将学生对象存入lsit集合

55 list.add(stu);

56 }
          //循环输出查询到的结果

57 for (Student stu : list) {

58 System.out.println(stu.getId() + "\t" + stu.getName() + "\t"

59 + stu.getAge() + "\t" + stu.getSex() + "\t"

60 + stu.getClassno());

61 }

62 } catch (ClassNotFoundException e) {

63 e.printStackTrace();

64 } catch (SQLException e) {

65 e.printStackTrace();

66 } finally {

67 // step7:关闭资源

68 // conn,statement,resultset

69 if (rSet != null) {

70 try {

71 rSet.close();

72 } catch (SQLException e) {

73 // TODO Auto-generated catch block

74 e.printStackTrace();

75 }

76 }

77 if (statement != null) {

78 try {

79 statement.close();

80 } catch (SQLException e) {

81 // TODO Auto-generated catch block

82 e.printStackTrace();

83 }

84 }

85 if (conn != null) {

86 try {

87 conn.close();

88 } catch (SQLException e) {

89 e.printStackTrace();

90 }

91 }

92 }

93

94 }

95

96 }

 

以上是 Java数据库编程--JDBC 的全部内容, 来源链接: utcz.com/z/394493.html

回到顶部