如何使用JDBC API从Oracle中的表中删除所有记录?

SQL TRUNCATE 语句用于删除表中的所有记录。

语法

TRUNCATE TABLE table_name;

要使用JDBC API从表中删除所有记录,您需要-

注册驱动程序:使用DriverManager 类的 registerDriver()方法注册驱动程序类。将驱动程序类名称作为参数传递给它。

建立连接:使用DriverManager 类的getConnection()方法连接到数据库。将URL(字符串),用户名(字符串),密码(字符串)作为参数传递给它。

创建语句:使用Connection 接口的createStatement()方法创建一个Statement对象。

执行查询:使用Statement接口的 execute() 方法执行查询。

以下JDBC程序与oracle数据库建立连接,并删除名为dispatchs的表中的所有记录-

示例

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class DeletingAllRows_Oracle {
   public static void main(String args[]) throws SQLException {
      //注册驱动程序
      DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
      //获得连接
      String oracleUrl = "jdbc:oracle:thin:@localhost:1521/xe";
      Connection con = DriverManager.getConnection(oracleUrl, "system", "password");
      System.out.println("Connection established......");
      //创建语句
      Statement stmt = con.createStatement();
      //查询以删除表中的所有记录
      String query = "Truncate table DISPATCHES";
      //执行查询
      stmt.execute(query);
      System.out.println("Table truncated....");
   }
}

输出结果

Connection established......
Table truncated....

删除后,如果使用select语句验证Dispatches表的内容,则输出为-

SQL> select * from dispatches;
no rows selected