sqlplus的一个有趣的命令选项

sqlplus -s:提供一个sqlplus的静默执行环境,不展示sqlplus执行信息。

[oracle@Vm3 u01]$ sqlplus -s "indiglib/indiglib as sysdba" <<eof
> select * from dual;
> select max(sequence#) from v\$log_history;
> eof


ADDR                   INDX    INST_ID D
---------------- ---------- ---------- -
00000000055299DC          0          1 X




MAX(SEQUENCE#)
--------------
            69


[oracle@Vm0 u01]$ sqlplus -s "indiglib/indiglib"<<eof >/u01/max_sn.log 
set head off;
set feedback off;
select max(sequence#) from v\$log_history;
exit;
eof




[oracle@Vm0 u01]$ more max_sn.log 


            69


来看一个删除dg备库过期归档日志文件的shell脚本:

#!/usr/bin/ksh

# created by tianlesoftware

# 2010/12/24

export ORACLE_HOME=/u01/app/oracle/product/10.2.0/db_1

export ORACLE_SID=xxxx

export SHELL_DIR=/u02/scripts

 

del_seq=`ls /u02/archivelog/|head -1|cut -f2 -d_`

echo $del_seq

$ORACLE_HOME/bin/sqlplus -s "user/pwd@sid_pd as sysdba" <<eof >/u02/scripts/max_sn.log

set head off;

set feedback;

select max(sequence#) from v/$log_history;

exit;

eof

max_sn=`cat /u02/scripts/max_sn.log|awk '{print $1}'|grep ^[0-9]`

max_sn=`expr $max_sn - 30`

-- 我这里是保留最近的30个归档文件,这个具体情况自己决定

echo $max_sn

while [ $del_seq -lt $max_sn ]

do

  rm /u02/archivelog/1_"$del_seq"_737806218.arc

-- 这里是我定义归档文件的格式,具体根据自己的归档文件格式来匹配,关键是匹配日志的sequence no

  del_seq=`expr $del_seq + 1`

  echo $del_seq

done

 

--max_sn.log 是存放最大seq tmp文件。 用来进行比较的

 

添加到crontab,定时执行:

[oracle@qs-xezf-db2 scripts]$ crontab -l

00 6 * * * /u02/scripts/del_st_archive.sh >/u02/scripts/del_st_arch.log 2>&1

 



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL*Plus是Oracle提供的一个基于文本的命令行工具,用于连接、管理和执行SQL语句和PL/SQL代码。下面是一些SQL*Plus命令的详细说明: 1. CONNECT:用于连接到一个Oracle数据库实例。可以指定用户名、密码和数据库名称。 2. SELECT:用于从数据库中检索数据。可以使用WHERE子句对数据进行筛选,并使用ORDER BY子句对结果进行排序。 3. INSERT:用于向数据库表中插入新的行。需要指定表名和要插入的值。 4. UPDATE:用于更新数据库表中的行。可以使用WHERE子句对要更新的行进行筛选,并指定要更新的字段和新值。 5. DELETE:用于删除数据库表中的行。同样可以使用WHERE子句对要删除的行进行筛选。 6. COMMIT:用于提交事务。将之前的SQL操作永久保存到数据库中。 7. ROLLBACK:用于回滚事务。取消之前的SQL操作,恢复到上一个提交点。 8. CREATE TABLE:用于创建新的数据库表。需要指定表名、字段名和数据类型。 9. ALTER TABLE:用于修改数据库表的结构。可以添加、修改或删除表的字段。 10. DROP TABLE:用于删除数据库表。 11. DESC:用于显示数据库表的结构,包括字段名、数据类型和约束。 12. SET AUTOTRACE:用于启用或禁用执行查询计划和统计信息的跟踪。 13. SET PAGESIZE:用于设置输出结果的页面大小。 14. SPOOL:用于将结果输出保存到一个文件中。 15. START:用于执行一个包含SQL*Plus命令脚本的文件。 16. EXIT或QUIT:用于退出SQL*Plus。 这些命令只是SQL*Plus的一部分功能,它还提供了很多其他命令选项,可以用于自定义和优化数据库查询和管理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值