Java编程 JDBC连接Oracle数据库
创始人
2024-03-29 21:18:49
0
  • Part1 JDBC

        JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。有了JDBC,向各种关系数据发送SQL语句就是一件很容易的事。换言之,有了JDBC API,就不必为访问Sybase数据库专门写一个程序,为访问oracle数据库又专门写一个程序。使开发人员能够更便捷的编写数据库应用程序。

  • Part2 JDBC连接数据库

         使用JDBC连接数据库简而言之包含了以下四个部分:加载驱动、连接数据库、创建statement对象、执行SQL命令。

1、加载驱动 

        JDBC在连接数据库前需要先加载驱动,通过java.lang.Class类的forName()实现驱动的加载。

Class.forName("oracle.jdbc.driver.OracleDriver");

2、连接数据库

        通过java.sql.DriverManager中的getConnection()方法获取一个Connection对象,即为创建一个数据库连接。

Connection conn = DriverManager.getConnection(url,username,passwd);
//url示例
jdbc:oracle:thin:@127.0.0.1:1521:orcl
jdbc:使用jdbc连接协议
oracle:使用oracle数据库
thin:oracle数据库连接模式,thin模式不需要安装客户端,oci模式需要安装客户端
@127.0.0.1:数据库地址
1521:数据库端口
orcl:数据库实例名

3、创建Statement对象

        在执行SQL语句前需要先创建statement对象。

Statement stmt = conn.createStatement();

4、执行SQL

        Statement有三种执行SQL语句的方法:

①executeQuery  此方法用来执行select语句,返回查询到的结果集。

②executeUpdate  此方法用来执行insert、update或delete语句以及SQL DDL(数据定义语言)语句,例如create table和drop table。insert、update或delete语句的效果是修改表中零行或多行中的一列或多列。返回值为一个整数,指受到影响的行数(即更新计数)。对于create table或drop table等不操作行的语句,返回值总为零。

③execute  此方法可用于执行任意SQL语句,返回值为boolean型,执行结果为ResultSet返回true,否则返回false。

String query="select * from user where id=1";
ResultSet rs=stmt.executeQuery(query);
  • Part3 数据后续处理

        通过对ResultSet结果集进行索引获取详细数据信息,或是使用get方法获取指定的字段信息。

while(rs.next()){System.out.println("编号为:"+rs.getInt("id")+"姓名为:"+rs.getString("username"));
}

        在使用完数据库连接后需要立马释放连接,否则时间长时间未关闭连接会导致服务器资源占用,甚至出现宕机状态。

rs.close();  //关闭ResultSet对象
stmt.close();  //关闭Statement对象
conn.close();  //关闭Connection对象

        完整JDBC连接Oracle数据库示例

import java.sql.*;
public class jdbctest {public static void main(String[] args) {String url= "jdbc:oracle:thin:@127.0.0.1:1521:myorcl";String user="sys as sysdba";String password="123";try {Class.forName("oracle.jdbc.driver.OracleDriver");Connection conn= DriverManager.getConnection(url,user,password);System.out.println("successfully");Statement stmt=conn.createStatement();String query="select passwd from users where id=9";ResultSet rs=stmt.executeQuery(query);while(rs.next()){System.out.println("编号为:"+rs.getInt("id")+"姓名为:"+rs.getString("username"));}rs.close();stmt.close();conn.close();} catch (Exception e) {e.printStackTrace();}}}

口令输入为‘sys as sysdba’,如果只输入sys则会报错java.sql.SQLException: ORA-28009: 应当以 SYSDBA 身份或 SYSOPER 身份建立 SYS 连接

相关内容

热门资讯

谁可以给我说,古代诗词的韵分哪... 谁可以给我说,古代诗词的韵分哪几种?非常感谢 古代诗词用韵,不同时期有差别。使用时间最长、影响最广、...
郑煤机(00564)中文名称变... 郑煤机(00564)发布公告,于2025年7月7日,公司完成了公司名称的工商变更登记手续,并取得了郑...
国足0比3不意外 转自:京报网_北京日报官方网站 【#国足0比3不意外#】...
有关中国古代天文学的书 有关中国古代天文学的书中国大百科全书-天文卷
浙富控股A股股东户数增加220... 7月7日消息,数据显示,截至2025年6月30日,浙富控股A股股东总户数为9.48万户,较上期(20...
ST路通A股股东户数增加100... 7月7日消息,数据显示,截至2025年6月30日,ST路通(维权)A股股东总户数为6500户,较上期...
绿茵逐梦,点亮未来 —— 华贸... 转自:扬子晚报今夏,华贸公益基金会与爱德基金会合作,邀请“少年足球梦”受助儿童走进南京和苏州,体验江...
70年代家庭教育故事? 70年代家庭教育故事?我们那时家庭教育父母总是让吃穿节省节约,奉行新三年,旧三年,缝缝补补又三年。
台风“丹娜丝”送清凉,江苏淮河... 转自:扬子晚报扬子晚报7月7日讯(记者 万惠娟)7日是小暑节气,小暑的到来标志我国大部分地区进入炎热...
儿童亡羊补牢怎么画 儿童亡羊补牢怎么画儿童亡羊补牢画法如下:1、先画牧童的头发和脸。2、再画牧童的眼睛。3、再画牧童的一...