Java数据库编程--JDBC

简介: 一、定义 JDBC,Java DataBase Connectivity。 是Java运行平台核心类库中的一部分,提供了访问数据库的API,由一些Java类和接口组成。 在Java中可以使用JDBC实现对数据库中表记录的查询,修改,和删除等操作 JDBC技术在数据库开发中占有很重要的地位。

一、定义

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 }

 

相关文章
|
10天前
|
安全 Java 开发者
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第9天】本文将深入探讨Java并发编程的核心概念,包括线程安全和性能优化。我们将详细解析Java中的同步机制,包括synchronized关键字、Lock接口以及并发集合等,并探讨它们如何影响程序的性能。此外,我们还将讨论Java内存模型,以及它如何影响并发程序的行为。最后,我们将提供一些实用的并发编程技巧和最佳实践,帮助开发者编写出既线程安全又高效的Java程序。
22 3
|
14天前
|
Java 调度
Java并发编程:深入理解线程池的原理与实践
【4月更文挑战第6天】本文将深入探讨Java并发编程中的重要概念——线程池。我们将从线程池的基本原理入手,逐步解析其工作过程,以及如何在实际开发中合理使用线程池以提高程序性能。同时,我们还将关注线程池的一些高级特性,如自定义线程工厂、拒绝策略等,以帮助读者更好地掌握线程池的使用技巧。
|
13天前
|
设计模式 安全 Java
Java并发编程实战:使用synchronized关键字实现线程安全
【4月更文挑战第6天】Java中的`synchronized`关键字用于处理多线程并发,确保共享资源的线程安全。它可以修饰方法或代码块,实现互斥访问。当用于方法时,锁定对象实例或类对象;用于代码块时,锁定指定对象。过度使用可能导致性能问题,应注意避免锁持有时间过长、死锁,并考虑使用`java.util.concurrent`包中的高级工具。正确理解和使用`synchronized`是编写线程安全程序的关键。
|
12天前
|
Java
Java 并发编程:深入理解线程池
【4月更文挑战第8天】本文将深入探讨 Java 中的线程池技术,包括其工作原理、优势以及如何使用。线程池是 Java 并发编程的重要工具,它可以有效地管理和控制线程的执行,提高系统性能。通过本文的学习,读者将对线程池有更深入的理解,并能在实际开发中灵活运用。
|
8天前
|
安全 算法 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第11天】 在Java中,高效的并发编程是提升应用性能和响应能力的关键。本文将探讨Java并发的核心概念,包括线程安全、锁机制、线程池以及并发集合等,同时提供实用的编程技巧和最佳实践,帮助开发者在保证线程安全的前提下,优化程序性能。我们将通过分析常见的并发问题,如竞态条件、死锁,以及如何利用现代Java并发工具来避免这些问题,从而构建更加健壮和高效的多线程应用程序。
|
12天前
|
Java
Java并发编程:深入理解线程池
【4月更文挑战第7天】在现代软件开发中,多线程编程已经成为一种不可或缺的技术。为了提高程序性能和资源利用率,Java提供了线程池这一强大工具。本文将深入探讨Java线程池的原理、使用方法以及如何根据实际需求定制线程池,帮助读者更好地理解和应用线程池技术。
15 0
|
13天前
|
缓存 安全 Java
Java并发编程进阶:深入理解Java内存模型
【4月更文挑战第6天】Java内存模型(JMM)是多线程编程的关键,定义了线程间共享变量读写的规则,确保数据一致性和可见性。主要包括原子性、可见性和有序性三大特性。Happens-Before原则规定操作顺序,内存屏障和锁则保障这些原则的实施。理解JMM和相关机制对于编写线程安全、高性能的Java并发程序至关重要。
|
2天前
|
安全 Java 调度
Java并发编程:深入理解线程与锁
【4月更文挑战第18天】本文探讨了Java中的线程和锁机制,包括线程的创建(通过Thread类、Runnable接口或Callable/Future)及其生命周期。Java提供多种锁机制,如`synchronized`关键字、ReentrantLock和ReadWriteLock,以确保并发访问共享资源的安全。此外,文章还介绍了高级并发工具,如Semaphore(控制并发线程数)、CountDownLatch(线程间等待)和CyclicBarrier(同步多个线程)。掌握这些知识对于编写高效、正确的并发程序至关重要。
|
2天前
|
缓存 分布式计算 监控
Java并发编程:深入理解线程池
【4月更文挑战第17天】在Java并发编程中,线程池是一种非常重要的技术,它可以有效地管理和控制线程的执行,提高系统的性能和稳定性。本文将深入探讨Java线程池的工作原理,使用方法以及在实际开发中的应用场景,帮助读者更好地理解和使用Java线程池。
|
3天前
|
SQL 缓存 Java
Java数据库连接池:优化数据库访问性能
【4月更文挑战第16天】本文探讨了Java数据库连接池的重要性和优势,它能减少延迟、提高效率并增强系统的可伸缩性和稳定性。通过选择如Apache DBCP、C3P0或HikariCP等连接池技术,并进行正确配置和集成,开发者可以优化数据库访问性能。此外,批处理、缓存、索引优化和SQL调整也是提升性能的有效手段。掌握数据库连接池的使用是优化Java企业级应用的关键。