前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java数据库编程--JDBC

Java数据库编程--JDBC

作者头像
听着music睡
发布2018-05-18 12:20:14
1.1K0
发布2018-05-18 12:20:14
举报
文章被收录于专栏:Android干货Android干货

一、定义

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桥接器。

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

建立桥接器的代码:

代码语言:javascript
复制
1 try{Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
2 }
3 catch(ClassNotFoundException e){
4         System.out.println(e);   
5 }

三、建立连接

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

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

代码语言:javascript
复制
1 Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","login name","passworf");

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

代码语言:javascript
复制
1 1 Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","","");

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

代码语言:javascript
复制
1 try{Connection con = DriverManager.getConnection("jdbc:odbc:数据源名字","","");}
2 catch(SQLException e){}

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

四、示例

代码语言:javascript
复制
 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 }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013-04-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档