Java JDBC编程

目录

一,JDBC概述

JDBC API

 JDBC工作流程: 

JDBC驱动程序类型

桥连

纯Java驱动

二, JDBC驱动与连接

驱动程序的加载

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

三,事务处理

四,Statement

五,ResultSet

数据类型的转换

 日期类型数据的处理

Null与零数值

六,PreparedStatement

七,CallableStatement


一,JDBC概述

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

JDBC API

提供者:sun公司

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

集成在java.sqljavax.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( )来实现

System.setProperty(“jdbc.drivers”,  

                           “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存储过程名(?,?,?)}”)
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值