如何利用BAT文件登陆OracleSql并执行多个sql脚本PLSQL语句?

发布网友 发布时间:2022-04-23 03:48

我来回答

2个回答

懂视网 时间:2022-04-07 20:21


DECLARE  
  V_SQL_DROP_TABLE   VARCHAR2(50) := ‘DROP TABLE MY_TEST2‘;  
  V_SQL_CREATE_TABLE VARCHAR2(100) := ‘CREATE TABLE MY_TEST2(NOT_NULL VARCHAR2(20) NOT NULL, ONLY_INT INTEGER)‘;  
BEGIN  
  EXECUTE IMMEDIATE V_SQL_CREATE_TABLE; -- 创建测试表  
EXCEPTION  
  -- 如果表已存在,则会引发异常  
  WHEN OTHERS THEN  
    EXECUTE IMMEDIATE V_SQL_DROP_TABLE; -- 先删除  
    EXECUTE IMMEDIATE V_SQL_CREATE_TABLE; -- 再创建  
END;  
/  
--2.用我们刚创建的测试表进行测试  
DECLARE   
  V_COUNT INTEGER; -- 表中记录的行数  
  V_INT_VAL MY_TEST.ONLY_INT%TYPE; -- 使用%TYPE关键字参照某表某字段类型声明变量  
BEGIN  
  V_INT_VAL := 123456;  
  -- 插入一条正确的数据  
  INSERT INTO MY_TEST2 VALUES (‘TEST_SUCCESS‘, V_INT_VAL);  
  -- 查询条数为1条,我们发现插入成功了  
  SELECT COUNT(*) INTO V_COUNT FROM MY_TEST;  
  DBMS_OUTPUT.put_line(‘MY_TEST表中有‘ || V_COUNT || ‘条记录‘);  
 
  -- 插入一条错误的数据,因为第二个字段为int型,插入字符数据肯定会出错  
 /* INSERT INTO MY_TEST VALUES (‘TEST_FAIL‘, ‘ABC‘);  */
 
  -- 最后提交更改  
  COMMIT;  
EXCEPTION  
  -- 异常处理  
  WHEN OTHERS THEN  
    ROLLBACK; -- 异常时回滚,这样第一次插入的正确数据也不会保存到数据库  
    DBMS_OUTPUT.put_line(‘[PL/SQL 事务]中出现异常,错误代码:ORA‘ || sqlcode);  
    -- 我们验证一下表里的数据为0条  
    SELECT COUNT(*) INTO V_COUNT FROM MY_TEST;  
    DBMS_OUTPUT.put_line(‘回滚后,MY_TEST表中有‘ || V_COUNT || ‘条记录‘);  
END; -- 可执行语句结束  
/ -- 该符号表示执行这段PL/SQL代码

oracle执行多个pl/sql块

标签:

热心网友 时间:2022-04-07 17:29

首先,做一个简单的sql文件(log.sql)。

在这个SQL文件中我们创建了一个表。

接下来,我们来建一个bat批处理文件(log.bat)。

在这个bat文件里面我们调用绝对路径的sql文件,并将执行过程及结果输出到log.txt文件中。

最后,我们运行bat文件,执行多个sql脚本plsql语句。

bat文件调用数据库中的存储过程:

假设数据库中一个存储过程,名称为Proce_log

我们只需要修改的sql文件如下即可:

execute Proce_log;

exit;

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com