Java JDBC编程

简介: Java JDBC编程

一,JDBC概述

JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力。

JDBC API

提供者:sun公司

内容:供程序员调用的接口与类

集成在java.sql和javax.sql包中


DriverManager类


Connection接口


Statement接口


ResultSet接口


DriverManager


提供者:sun公司


作用:载入各种不同的JDBC驱动


JDBC 驱动


提供者:数据库厂商作用:负责连接各种不同的数据库

JDBC工作流程:

与数据库建立连接、执行SQL 语句、处理结果

DriverManager:依据数据库的不同,管理JDBC驱动

Connection :负责连接数据库并担任传送数据的任务  

Statement Connection 产生、负责执行SQL语句

ResultSet:负责保存Statement执行后所产生的查询结果

JDBC驱动程序类型

桥连

将对JDBC API的调用,转换为对另一组数据库连接API的调用

优点:可以访问所有ODBC可以访问的数据库

缺点:执行效率低、功能不够强大

Java驱动

JDBC驱动直接访问数据库

优点:100% Java,快速又可跨平台

缺点:访问不同数据库需下载专用的JDBC

二, JDBC驱动与连接

驱动程序的加载

使用Class类中的静态方法forName( )来实现

Class.forName(“oracle.jdbc.driver.OracleDriver”);

直接创建一个驱动程序的对象

new oracle.jdbc.driver.OracleDriver( );

使用System类中的静态方法setProperty( )来实现

1. System.setProperty(“jdbc.drivers”,  
2. 
3.                            “oracle.jdbc.driver.OracleDriver”)

建立数据库连接(纯Java驱动方式)

下载数据库厂商提供的驱动程序包

将驱动程序包引入工程中

编程,通过纯Java驱动方式与数据库建立连接

//

url代表数据库的资源定位,格式:jdbc:驱动器类型:数据库资源。
String URL=“jdbc:oracle:thin:@localhost:1521:ora";
Class.forName(“oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection(URL,“scott",“tiger");

三,事务处理

事务定义

指用户定义的数据库操作序列要么全执行,要么全不执行,事务是不可分割的工作单位。

事务处理的方式

提交事务commit()

回滚事务rollback()

取消事务自动提交模式

setAutoCommit(false)

四,Statement

创建Statement对象

Statement对象主要方法

executeQuery执行查询语句 ,返回ResultSet对象

executeUpdate执行DML语句等


能执行任何语句操作的execute(),返回boolean值,表示语句是否执行成功


由Connection对象创建

stmt=conn.createStatement();
ResultSet rs=stmt.executeQuery(sql);
int i=stmt.executeUpdate(sql);
boolean b=stmt. execute(sql);

五,ResultSet

通常执行一个查询语句后,会返回一个结果集

获取结果集中的数据

通过列名来获取某个字段的数据

通过列的索引(1开始)获取某个字段的数据

数据类型的转换

日期类型数据的处理

通常在数据库中处理,Oracle中采用的方式:

TO_CHAR(日期,格式字符)

TO_DATE(格式字符)

Null与零数值

NULL是SQL中一个很特殊的值 ,不是数值类型0

表示的是数据库中的某列没有定义任何的数据

ResultSet 提供了测试数据库中某列是否为NULL的方法wasNull()

六,PreparedStatement

PreparedStatement接口继承 Statement接口

PreparedStatement比普通的Statement对象使用起来更加灵活,更有效率。


当 SQL 语句将运行多次时,尽量使用PreparedStatement,以便提高运行效率

七,CallableStatement

调用数据库中的存储过程

创建CallableStatement对象

不带参数的存储过程

CallableStatement cs = conn.preparedCall (“{call存储过程名()}”);

传入IN参数的存储过程

CallableStatement cs = conn.preparedCall (“{call存储过程名(?,?,?)}”);

传入IN或者OUT参数的存储过程

CallableStatement cs = conn.preparedCall (“{? = call存储过程名(?,?,?)}”)


目录
相关文章
|
1天前
|
存储 Java
JAVA并发编程AQS原理剖析
很多小朋友面试时候,面试官考察并发编程部分,都会被问:说一下AQS原理。面对并发编程基础和面试经验,专栏采用通俗简洁无废话无八股文方式,已陆续梳理分享了《一文看懂全部锁机制》、《JUC包之CAS原理》、《volatile核心原理》、《synchronized全能王的原理》,希望可以帮到大家巩固相关核心技术原理。今天我们聊聊AQS....
|
1天前
|
Java 程序员 数据库连接
Java编程中的异常处理:从基础到进阶
【9月更文挑战第18天】在Java的世界里,异常处理是每个程序员必须面对的挑战。本文将带你从异常的基本概念出发,通过实际的代码示例,深入探讨如何有效地管理和处理异常。我们将一起学习如何使用try-catch块来捕捉异常,理解finally块的重要性,以及如何自定义异常类来满足特定需求。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的见解和技巧,让你的Java代码更加健壮和可靠。
|
1天前
|
Java 数据库连接 UED
掌握Java编程中的异常处理
【9月更文挑战第18天】在Java的世界中,异常是那些不请自来的客人,它们可能在任何时候突然造访。本文将带你走进Java的异常处理机制,学习如何优雅地应对这些突如其来的“访客”。从基本的try-catch语句到更复杂的自定义异常,我们将一步步深入,确保你能够在面对异常时,不仅能够从容应对,还能从中学到宝贵的经验。让我们一起探索如何在Java代码中实现健壮的异常处理策略,保证程序的稳定运行。
|
2天前
|
Java 数据库
JAVA并发编程-一文看懂全部锁机制
曾几何时,面试官问:java都有哪些锁?小白,一脸无辜:用过的有synchronized,其他不清楚。面试官:回去等通知! 今天我们庖丁解牛说说,各种锁有什么区别、什么场景可以用,通俗直白的分析,让小白再也不怕面试官八股文拷打。
|
8天前
|
缓存 Java 编译器
JAVA并发编程volatile核心原理
volatile是轻量级的并发解决方案,volatile修饰的变量,在多线程并发读写场景下,可以保证变量的可见性和有序性,具体是如何实现可见性和有序性。以及volatile缺点是什么?
|
2天前
|
Java
深入理解Java中的多线程编程
本文将探讨Java多线程编程的核心概念和技术,包括线程的创建与管理、同步机制以及并发工具类的应用。我们将通过实例分析,帮助读者更好地理解和应用Java多线程编程,提高程序的性能和响应能力。
15 4
|
10天前
|
Java 调度 开发者
Java并发编程:深入理解线程池
在Java的世界中,线程池是提升应用性能、实现高效并发处理的关键工具。本文将深入浅出地介绍线程池的核心概念、工作原理以及如何在实际应用中有效利用线程池来优化资源管理和任务调度。通过本文的学习,读者能够掌握线程池的基本使用技巧,并理解其背后的设计哲学。
|
2天前
|
安全 Java 开发者
Java并发编程中的锁机制解析
本文深入探讨了Java中用于管理多线程同步的关键工具——锁机制。通过分析synchronized关键字和ReentrantLock类等核心概念,揭示了它们在构建线程安全应用中的重要性。同时,文章还讨论了锁机制的高级特性,如公平性、类锁和对象锁的区别,以及锁的优化技术如锁粗化和锁消除。此外,指出了在高并发环境下锁竞争可能导致的问题,并提出了减少锁持有时间和使用无锁编程等策略来优化性能的建议。最后,强调了理解和正确使用Java锁机制对于开发高效、可靠并发应用程序的重要性。
12 3
|
1天前
|
安全 Java 调度
Java 并发编程中的线程安全和性能优化
本文将深入探讨Java并发编程中的关键概念,包括线程安全、同步机制以及性能优化。我们将从基础入手,逐步解析高级技术,并通过实例展示如何在实际开发中应用这些知识。阅读完本文后,读者将对如何在多线程环境中编写高效且安全的Java代码有一个全面的了解。
|
2天前
|
安全 Java API
JAVA并发编程JUC包之CAS原理
在JDK 1.5之后,Java API引入了`java.util.concurrent`包(简称JUC包),提供了多种并发工具类,如原子类`AtomicXX`、线程池`Executors`、信号量`Semaphore`、阻塞队列等。这些工具类简化了并发编程的复杂度。原子类`Atomic`尤其重要,它提供了线程安全的变量更新方法,支持整型、长整型、布尔型、数组及对象属性的原子修改。结合`volatile`关键字,可以实现多线程环境下共享变量的安全修改。