45个非常有用的Oracle查询语句小结(一)

2014-11-24 12:24:51 · 作者: · 浏览: 2

这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询。这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧。

原文地址:http://www.jbxue.com/db/19890.html

日期/时间 相关查询

1.获取当前月份的第一天

运行这个命令能快速返回当前月份的第一天。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下:
SELECT TRUNC (SYSDATE, 'MONTH') "First day of current month"
FROM DUAL;

2.获取当前月份的最后一天

这个查询语句类似于上面那个语句,而且充分照顾到了闰年,所以当二月份有 29 号,那么就会返回 29/2 。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下:
SELECT TRUNC (LAST_DAY (SYSDATE)) "Last day of current month"
FROM DUAL;

3.获取当前年份的第一天
每年的第一天都是1 月1日,这个查询语句可以使用在存储过程中,需要对当前年份第一天做一些计算的时候。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下:
SELECT TRUNC (SYSDATE, 'YEAR') "Year First Day" FROM DUAL;

4.获取当前年份的最后一天

类似于上面的查询语句。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下: SELECT ADD_MONTHS (TRUNC (SYSDATE, 'YEAR'), 12) - 1 "Year Last Day" FROM DUAL

5.获取当前月份的天数

这个语句非常有用,可以计算出当前月份的天数。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下:
SELECT CAST (TO_CHAR (LAST_DAY (SYSDATE), 'dd') AS INT) number_of_days FROM DUAL;

6.获取当前月份剩下的天数
下面的语句用来计算当前月份剩下的天数。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下:
SELECT SYSDATE,
LAST_DAY (SYSDATE) "Last",
LAST_DAY (SYSDATE) - SYSDATE "Days left"
FROM DUAL;

7.获取两个日期之间的天数
使用这个语句来获取两个不同日期自检的天数。

复制代码代码如下:
SELECT ROUND ( (MONTHS_BETWEEN ('01-Feb-2014', '01-Mar-2012') * 30), 0) num_of_days FROM DUAL;
OR
SELECT TRUNC(sysdate) - TRUNC(e.hire_date) FROM employees;

如果你需要查询一些特定日期的天数,可以使用第二个查询语句。这个例子是计算员工入职的天数。

8.显示当前年份截止到上个月每个月份开始和结束的日期

这个是个很聪明的查询语句,用来显示当前年份每个月的开始和结束的日期,你可以使用这个进行一些类型的计算。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。

复制代码代码如下:
SELECT ADD_MONTHS (TRUNC (SYSDATE, 'MONTH'), i) start_date,
TRUNC (LAST_DAY (ADD_MONTHS (SYSDATE, i))) end_date
FROM XMLTABLE (
'for $i in 0 to xs:int(D) return $i'
PASSING XMLELEMENT (
d,
FLOOR (
MONTHS_BETWEEN (
ADD_MONTHS (TRUNC (SYSDATE, 'YEAR') - 1, 12),
SYSDATE)))
COLUMNS i INTEGER PATH '.');

9.获取直到目前为止今天过去的秒数(从 00:00 开始算)

复制代码代码如下: SELECT (SYSDATE - TRUNC (SYSDATE)) * 24 * 60 * 60 num_of_sec_since_morning FROM DUAL;

10.获取今天剩下的秒数(直到 23:59:59 结束)

复制代码代码如下: SELECT (TRUNC (SYSDATE+1) - SYSDATE) * 24 * 60 * 60 num_of_sec_left FROM DUAL;

数据字典查询

11.检查在当前数据库模式下是否存在指定的表

这是一个简单的查询语句,用来检查当前数据库是否有你想要创建的表,允许你重新运行创建表脚本,这个也可以检查当前用户是否已经创建了指定的表(根据这个查询语句在什么环境下运行来查询)。

复制代码代码如下:
SELECT table_name
FROM user_tables
WHERE table_name = 'TABLE_NAME';

12.检查在当前表中是否存在指定的列

这是个简单的查询语句来检查表里是否有指定的列,在你尝试使用 ALTER TABLE 来添加新的列新到表中的时候非常有用,它会提示你是否已经存在这个列。

复制代码代码如下:
SELECT column_name AS FOUND
FROM user_tab_cols
WHERE table_name = 'TABLE_NAME' AND column_name = 'COLUMN_NAME';

13.显示表结构

这 个查询语句会显示任何表的 DDL 状态信息。请注意我们已经将‘TABLE'作为第一个信息提交了。这个查询语句也可以用来获取任何数据库对象的 DDL 状态信息。举例说明,只需要把第一个参数替换成‘VIEW',第二个修改成视图的名字,就可以查询视图的 DDL 信息了。

复制代码代码如下:
SELECT DBMS_METADATA.get_ddl ('TABLE', 'TABLE_NAME', 'USER_NAME') FROM DUAL;

14.获取当前模式
这是另一个可以获得当前模式的名字的查询语句。

复制代码代码如下:
SELECT SYS_CONTEXT ('userenv', 'current_schema') FROM DUAL;

15.修改当前模式
这是另一个可以修改当前模式的查询语句,当你希望你的脚本可以在指定的用户下运行的时候非常有用,而且这是非常安全的一个方式。

复制代码代码如下:
ALTER SESSION SET CURRENT_SCHEMA = new_schema;

数据库管理查询

16.数据库版本信息

返回 Oracle 数据库版本

复制代码代码如下:
SELECT * FROM v$version;

17.数据库默认信息

返回一些系统默认的信息

复制代码代码如下:
SELECT username,
profile,
default_tablespace,
temporary_tablespace
FROM dba_users;

18.数据库字符设置信息
显示数据库的字符设置信息

复制代码代码如下:
SELECT * FROM nls_database_parameters;

19.获取 Oracle 版本

复制代码代码如下:
SELECT VALUE
FROM v$syste