用户名: 密码: 免费注册 忘记密码? 网站地图 | 加入收藏 | 设为首页
首页 | 新闻 | 工具 | 系统 | 办公 | 聊天 | 多媒体 | 网页 | 运营 | 平面 | 欣赏 | 数据库 | 程序 | 服务器 | 组网
网页 | 3dmax | Ghost | Windows Xp| Dreamweaver | photoshop | Flash | office | Alexa | Css | QQ | Asp | PHP | Jsp | Access
Flash MX 2004入门 | 网站推广策略 | CorelDRAW入门 | ASP学习 | 网站建设大师功 | Word入门
  iTbulo.com > 学院 > 数据库开发教程 > Oracle教程 > Oracle实例应用 > 文章正文
ORACLE问题与解答
iTbulo.COM 2005-10-19 未知()

99. 怎样判断数据库是运行在归档模式下还是运行在非归档模式下?
进入dbastudio,历程--〉数据库---〉归档查看。

100. sql>startup pfile和ifile,spfiled有什幺区别?
pfile就是Oracle传统的初始化参数文件,文本格式的。
ifile类似于c语言里的include,用于把另一个文件引入
spfile是9i里新增的并且是默认的参数文件,二进制格式
startup后应该只可接pfile

101. 如何搜索出前N条记录?
SELECT * FROM empLOYEE WHERE ROWNUM < n
ORDER BY empno;

102. 如何知道机器上的Oracle支持多少并发用户数?
  SQL>conn internal ;
SQL>show parameter processes ;

103. db_block_size可以修改吗?
   一般不可以﹐不建议这样做的。

104. 如何统计两个表的记录总数?
  select (select count(id) from aa)+(select count(id) from bb) 总数 from dual;

105. 怎样用Sql语句实现查找一列中第N大值?
  select * from
(select t.*,dense_rank() over (order by sal) rank from employee)
where rank = N;

106. 如何在给现有的日期加上2年?(
   select add_months(sysdate,24) from dual;

107. USED_UBLK为负值表示什幺意思?
It is "harmless".

108. Connect string是指什幺?
应该是tnsnames.ora中的服务名后面的内容

109. 怎样扩大REDO LOG的大小?

 建立一个临时的redolog组,然后切换日志,删除以前的日志,建立新的日志。

110. tablespace 是否不能大于4G?
  没有限制.

111. 返回大于等于N的最小整数值?
   SELECT CEIL(N) FROM DUAL;

112. 返回小于等于N的最小整数值?
   SELECT FLOOR(N) FROM DUAL;

113. 返回当前月的最后一天?
   SELECT LAST_DAY(SYSDATE) FROM DUAL;

114. 如何不同用户间数据导入?
  IMP SYSTEM/MANAGER FILE=AA.DMP FROMUSER=USER_OLD  TOUSER=USER_NEW ROWS=Y INDEXES=Y ;


115. 如何找数据库表的主键字段的名称?

  SQL>SELECT * FROM user_constraints WHERE CONSTRAINT_TYPE='P' and  table_name='TABLE_NAME';


116. 两个结果集互加的函数?

  SQL>SELECT * FROM BSEMPMS_OLD INTERSECT SELECT * FROM BSEMPMS_NEW;
  SQL>SELECT * FROM BSEMPMS_OLD UNION SELECT * FROM BSEMPMS_NEW;
  SQL>SELECT * FROM BSEMPMS_OLD UNION ALL SELECT * FROM BSEMPMS_NEW;


117. 两个结果集互减的函数?
SQL>SELECT * FROM BSEMPMS_OLD MINUS SELECT * FROM BSEMPMS_NEW;


118. 如何配置Sequence?

  建sequence seq_custid
  create sequence seq_custid start 1 incrememt by 1;
  建表时:
  create table cust
  { cust_id smallint not null,
  ...}
  insert 时:
  insert into table cust
  values( seq_cust.nextval, ...)

日期的各部分的常用的的写法
119>.取时间点的年份的写法:
   SELECT TO_CHAR(SYSDATE,'YYYY') FROM DUAL;

120>.取时间点的月份的写法:
   SELECT TO_CHAR(SYSDATE,'MM') FROM DUAL;

121>.取时间点的日的写法:
   SELECT TO_CHAR(SYSDATE,'DD') FROM DUAL;

122>.取时间点的时的写法:
   SELECT TO_CHAR(SYSDATE,'HH24') FROM DUAL;

123>.取时间点的分的写法:
   SELECT TO_CHAR(SYSDATE,'MI') FROM DUAL;

124>.取时间点的秒的写法:
   SELECT TO_CHAR(SYSDATE,'SS') FROM DUAL;

125>.取时间点的日期的写法:
   SELECT TRUNC(SYSDATE) FROM DUAL;

126>.取时间点的时间的写法:
   SELECT TO_CHAR(SYSDATE,'HH24:MI:SS') FROM DUAL;

127>.日期,时间形态变为字符形态
   SELECT TO_CHAR(SYSDATE) FROM DUAL;

128>.将字符串转换成日期或时间形态:
   SELECT TO_DATE('2003/08/01') FROM DUAL;

129>.返回参数的星期几的写法:
   SELECT TO_CHAR(SYSDATE,'D') FROM DUAL;

130>.返回参数一年中的第几天的写法:
   SELECT TO_CHAR(SYSDATE,'DDD') FROM DUAL;

131>.返回午夜和参数中指定的时间值之间的秒数的写法:
   SELECT TO_CHAR(SYSDATE,'SSSSS') FROM DUAL;

132>.返回参数中一年的第几周的写法:
   SELECT TO_CHAR(SYSDATE,'WW') FROM DUAL;
虚拟字段

133. CURRVAL 和 nextval
  为表创建序列
  CREATE SEQUENCE EMPSEQ ... ;
  SELECT empseq.currval FROM DUAL ;
  自动插入序列的数值
  INSERT INTO emp
  VALUES (empseq.nextval, 'LEWIS', 'CLERK',
7902, SYSDATE, 1200, NULL, 20) ;

134. ROWNUM
  按设定排序的行的序号
  SELECT * FROM emp WHERE ROWNUM < 10 ;

135. ROWID
  返回行的物理地址
  SELECT ROWID, ename FROM emp WHERE deptno = 20 ;

136. 将N秒转换为时分秒格式?
  set serverout on
  declare
  N number := 1000000;
  ret varchar2(100);
  begin
  ret := trunc(n/3600) || '小时' || to_char(to_date(mod(n,3600),'sssss'),'fmmi"分  "ss"秒"') ;
  dbms_output.put_line(ret);
  end;

137. 如何查询做比较大的排序的进程?
  SELECT b.tablespace, b.segfile#, b.segblk#, b.blocks, a.sid, a.serial#,
  a.username, a.osuser, a.status
  FROM v$session a,v$sort_usage b
  WHERE a.saddr = b.session_addr
  ORDER BY b.tablespace, b.segfile#, b.segblk#, b.blocks ;

138. 如何查询做比较大的排序的进程的SQL语句?
  select /*+ ORDERED */ sql_text from v$sqltext a
  where a.hash_value = (
  select sql_hash_value from v$session b
  where b.sid = &sid and b.serial# = &serial)
  order by piece asc ;

139. 如何查找重复记录?
  SELECT * FROM TABLE_NAME
  WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAME D
  WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);

140. 如何删除重复记录?
  DELETE FROM TABLE_NAME
  WHERE ROWID!=(SELECT MAX(ROWID) FROM TABLE_NAME D
  WHERE TABLE_NAME.COL1=D.COL1 AND TABLE_NAME.COL2=D.COL2);

上一页  [1] [2] [3] [4] [5] [6] 下一页

文章搜索
相关资讯
相关文章 相关下载
没有相关文章
焦点信息