使用IDEA对Oracle数据库进行简单增删改查操作

 更新时间:2021年01月04日 14:34:20   作者:海绵宝宝的菠萝屋*  
这篇文章主要介绍了使用IDEA对Oracle数据库进行简单增删改查操作,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

1.1 Java中的数据存储技术

在Java中,数据库存取技术可分为如下几类:
1、JDBC直接访问数据库
2、JDO(Java Data Object)是Java对象持久化的新的规范,也是一个用于存取某种数据仓库中的对象的标准化API。
3、第三方O/R 比如Hibernate,Mybatis等

JDBC是java访问数据库的基石,JDO、Hibernate、MyBatis,JDO,Hibernate、MyBatyis等只是更好的封装的JDBC。
最近用idea连接Oracle数据库 并且实现增删改操作的时候,遇到的一些问题在这里跟大家分享一下。
首先,idea连接连接数据库,都需要进行Connnection,也就是需要jdbc(Java database connection)
在进行连接之前,最先要做的事情就是导入对应所使用的数据库的jar包。(常见的数据库有MySQL,Oracle,SQLServer等等)
举个例子:
我要连接Oracle数据库,就到Oracle的官网上下载对应的jar包,当引入jar包下面出现小三角的时候,就说明导包成功!!

在这里插入图片描述

第一步成功,我们套用jdbc的代码,基本上这个大家都能明白,咱也可以把它封装在一个类里边,必要的时候拿过来使用。
如下代码所示: 注意看代码的注释!!

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Scanner;
//与数据库建立连接
public class ConnectionTest {
  //获取连接的三个基本信息
  private String dbURL = "jdbc:oracle:thin:@localhost:1521:orcl";
  private String dbUser = "test";
  private String dbPwd = "test";
  // 获取数据库连接方法, 返回Connection对象
  private Connection con = null;
  //创建数据库连接
  public Connection getDBConnect() {
    try {
      // 加载数据库驱动 不同的数据库下面这个驱动是不同的,这个千万要注意!!!
      Class.forName("oracle.jdbc.driver.OracleDriver");
      con = DriverManager.getConnection(dbURL, dbUser, dbPwd);
    } catch (Exception e) {
      System.out.println(e);
    }
    return con;
  }
}

然后我们写一个主方法测试一下:也就是程序执行的出口,运行至下面这句话说明连接成功! 连接数据库成功仅仅是第二步,接下来更重要的是进行对数据库的增删改操作!!

在这里插入图片描述

连接数据库成功之后,就是为了下面增删改操作服务的。注意看对数据库进行插入操作的方法如下:(插入操作的方法要写在Connection这个类里边)

public void testInsert() {
	  PreparedStatement ps1 = null; //使用该类执行增删改操作不会发生sql注入现象!!
    //在进行插入操作的时候 保证你的表、以及对应的列名都存在 ?在这里表示占位符
    String sql = "insert into t_user(ID,USERNAME,PASSWORD1,EMAIL) values(?,?,?,?)";
    try {
     //1、预编译sql语句 返回PreparedStatement的实例给ps1 con表示Connection的对象
      ps1 = con.prepareStatement(sql);
      //2、填充占位符=?
      ps1.setString(1, "2");
      ps1.setString(2, "ww");
      ps1.setString(3, "12345");
      ps1.setString(4, "907372669@qq.com");
      //执行操作
      ps1.execute();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    //资源的关闭
    try {
      if (ps1 != null)
        ps1.close();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    try {
      if (con != null)
        con.close();
    } catch (SQLException e) {
      e.printStackTrace();
    }
  }

插入方法写好之后,在主函数里面调用即可实现插入操作,千万注意自己写的sql语句写的有没有存在问题。

在这里插入图片描述

同样往下是删除操作的方法(ps:注意观察关闭资源的方法,将其写在一个方法体里,减少代码的重用性!!)

public void testUpdate() {
    PreparedStatement ps2 = null;
    //编写sql语句 返回PreparedStatement的实例
    String sql = "update T_USER set USERNAME = ? where ID = ? ";
    try {
      ps2 = con.prepareStatement(sql);
       //填充占位符=?
      ps2.setObject(1,"newgg");
      ps2.setObject(2,"1");
      //执行
      ps2.execute();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    //实现资源关闭的方法
    closeSources(ps2,con);
  }
  
  //实现资源关闭的方法如下:
public void closeSources(PreparedStatement ps, Connection con) {
    try {
      if (ps != null)
        ps.close();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    try {
      if (con != null)
        con.close();
    } catch (SQLException e) {
      e.printStackTrace();
    }
}

接下来实现修改某一行的属性的方法,逻辑实现同插入删除一样。

public void testUpdate() {
 //编写sql语句 返回PreparedStatement的实例
    PreparedStatement ps2 = null;
    String sql = "update T_USER set USERNAME = ? where ID = ? ";
    try {
      ps2 = con.prepareStatement(sql);
      //填充占位符=?
      ps2.setObject(1,"newgg");
      ps2.setObject(2,"1");
      //执行
      ps2.execute();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    //实现资源的关闭
    closeSources(ps2,con);
  }

在这里插入图片描述

套路都是一样,细心的人会发现,增删改的操作步骤都是一样的,但唯独SQL语句不一样,进而填充占位符的参数是不一样的,利用Java 具有可变长参数的性质,我们可以写出一个通用的增删改的方法

 //实现增删改的通用操作
// sql占位符中的个数与可变长参数的长度一致!!
  public void insert_Delete_Update(String sql, Object ...args) {
   //预编译SQL语句,返回PreparedStatement的实例
    PreparedStatement ps4 = null;
    try {
      ps4 = con.prepareStatement(sql);
      //填充占位符
      for(int i=0; i<args.length; i++) {
        ps4.setObject(i+1,args[i]);
      }
      //执行
      ps4.execute();
    } catch (SQLException e) {
      e.printStackTrace();
    }
    //实现资源的关闭
    closeSources(ps4,con);
  }

于是进而实现代码块分离,SQL语句写在另一个方法里,代码实现如下:

 public void test_Insert_Delete_Update() {
 
    String sql1 = "update T_USER set username = ? where ID = ? ";
    //仔细观察这个调用的方法 username=“newQ” ID=“2”这两个参数传入这个方法里 
    insert_Delete_Update(sql1,"newQ","2");
  }

在主函数调用该方法,即可实现对表的增删改操作!

在这里插入图片描述

到此这篇关于使用IDEA对Oracle数据库进行简单增删改查操作的文章就介绍到这了,更多相关IDEA对Oracle数据库增删改查内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle实现查询2个日期所跨过的月份列表/日期列表的方法分析

    Oracle实现查询2个日期所跨过的月份列表/日期列表的方法分析

    这篇文章主要介绍了Oracle实现查询2个日期所跨过的月份列表/日期列表的方法,结合实例形式分析了Oracle日期相关查询与运算相关操作技巧,需要的朋友可以参考下
    2019-09-09
  • oracle区管理和段空间管理详细介绍

    oracle区管理和段空间管理详细介绍

    本文将详细介绍oracle区管理和段空间管理,需要的朋友可以参考下
    2012-11-11
  • 检查Oracle数据库版本的7种方法汇总

    检查Oracle数据库版本的7种方法汇总

    在Oracle数据库的发展中,数据库一直处于不断升级状态,下面这篇文章主要给大家介绍了关于检查Oracle数据库版本的7种方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • Oracle中带条件插入数据的使用方法示例详解

    Oracle中带条件插入数据的使用方法示例详解

    在Oracle数据库中,INSERT WHEN语句用于在满足特定条件时插入数据,它允许您根据条件控制插入操作是否执行,本文给大家分享Oracle中带条件插入数据的使用方法,感兴趣的朋友一起看看吧
    2023-12-12
  • PLSQLDeveloper登录远程连接Oracle的操作

    PLSQLDeveloper登录远程连接Oracle的操作

    这篇文章主要介绍了PLSQLDeveloper登录远程连接Oracle的操作方法,通过图文并茂给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • 关于Oracle中sqlldr的用法大全

    关于Oracle中sqlldr的用法大全

    这篇文章主要介绍了关于Oracle中sqlldr的用法大全,SQLLDR可以在极短的时间内加载数量庞大的数据,这是一个非常有用的工具,可用于从多种平面文件格式向Oracle数据库中加载数据,下面我们就来详细说明一下sqlldr的用法
    2023-07-07
  • oracle in长度限制的两个快速解决方法

    oracle in长度限制的两个快速解决方法

    这篇文章主要给大家介绍了关于oracle in长度限制的两个快速解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Oracle sql批量插入多条数据的实现

    Oracle sql批量插入多条数据的实现

    这篇文章主要介绍了Oracle sql批量插入多条数据的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Oracle查看表空间使用率以及爆满解决方案详解

    Oracle查看表空间使用率以及爆满解决方案详解

    在日常的oralce使用中最长遇到的问题就是oralce的表空间满了,数据无法写入报错,下面这篇文章主要给大家介绍了关于Oracle查看表空间使用率以及爆满解决的相关资料,需要的朋友可以参考下
    2022-07-07
  • Oracle到PostgreSQL的不停机数据库迁移的流程步骤

    Oracle到PostgreSQL的不停机数据库迁移的流程步骤

    这篇文章主要介绍了Oracle到PostgreSQL的不停机数据库迁移的流程步骤,Oracle 到 PostgreSQL 的迁移并不是说迁就能迁的,有很多不得不解决的问题,文中通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-05-05

最新评论