Oracle常用问题解答

 (1)[Q]如何插入单引号到数据库表中

[A]可以用ASCII码处理,其它特殊字符如&也一样,如
insert into t values('i'||chr(39)||'m'); -- chr(39)代表字符'
或者用两个单引号表示一个
or insert into t values('I''m'); -- 两个''可以表示一'
 
(2)[Q]随机抽取前N条记录的问题
[A]8i以上版本
select * from (select * from tablename order by dbms_random.value) where rownum< N;
注:dbms_random包需要手工安装,位于$ORACLE_HOME/rdbms/admin/dbmsrand.sql
dbms_random.value(100,200)可以产生100200范围的随机数
 
(3)[Q]怎么样抽取重复记录
[A]select * from table t1 where t1.rowid !=
(select max(rowid) from table t2
where t1.id=t2.id and t1.name=t2.name)
或者
select count(*), t.col_a,t.col_b from table t
group by col_a,col_b
having count(*)>1
如果想删除重复记录,可以把第一个语句的select替换为delete
 
(4)[Q]怎么样设置自治事务
[A]8i以上版本,不影响主事务
pragma autonomous_transaction;
……
commit|rollback;
 
(5)[Q]怎么样在过程中暂停指定时间
[A]DBMS_LOCK包的sleep过程
如:dbms_lock.sleep(5);表示暂停5秒。
 
(6)[Q]怎样创建临时表
[A]8i以上版本
create global temporary tablename(column list)
on commit preserve rows; --提交保留数据 会话临时表
on commit delete rows; --提交删除数据 事务临时表
临时表是相对于会话的,别的会话看不到该会话的数据
 
(7)[Q]怎么样在PL/SQL中执行DDL语句
[A]18i以下版本dbms_sql
28i以上版本还可以用
execute immediate sql;
dbms_utility.exec_ddl_statement('sql');
 
(8)[Q]怎么样获取IP地址
[A]服务器(817以上)utl_inaddr.get_host_address
客户端:sys_context('userenv','ip_address')
 
(9)[Q]怎么样在ORACLE中定时运行存储过程
[A]可以利用dbms_job包来定时运行作业,如执行存储过程,一个简单的例子,提交一个作业:
VARIABLE jobno number;
BEGIN
DBMS_JOB.SUBMIT(:jobno, 'ur_procedure;',SYSDATE,'SYSDATE + 1');
commit;
END;
之后,就可以用以下语句查询已经提交的作业
select * from user_jobs;
 
(10)[Q]怎么样从数据库中获得毫秒
[A]9i以上版本,有一个timestamp类型获得毫秒,如
SQL>select to_char(systimestamp,'yyyy-mm-dd hh24:mi:ssxff') time1,
to_char(current_timestamp) time2 from dual;
 
(11)[Q]怎么实现左联,右联与外联
[A]9i以前可以这么写:
左联:
select a.id,a.name,b.address from a,b
where a.id=b.id(+)
 
(12)9i以上,已经开始支持SQL99标准,所以,以上语句可以写成:
左联
select a.id,a.name,b.address
from a left outer join b on a.id=b.id
where other_clause
 
(13)[Q]怎么样把查询内容输出到文本
[A]spool
sqlplus –s " / as sysdba" <<EOF
set heading off
set feedback off
spool temp.txt
  select * from tab;
dbms_output.put_line(‘test’);
spool off
exit
EOF
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值