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

2015-02-02 23:09:34 · 作者: · 浏览: 27
日期/时间 相关查询
获取当前月份的第一天
运行这个命令能快速返回当前月份的第一天。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。
?
SELECT TRUNC (SYSDATE, 'MONTH') "First day of current month"?
? ? FROM DUAL;
获取当前月份的最后一天
这个查询语句类似于上面那个语句,而且充分照顾到了闰年,所以当二月份有 29 号,那么就会返回 29/2 。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。
?
SELECT TRUNC (LAST_DAY (SYSDATE)) "Last day of current month"?
? ? FROM DUAL;
获取当前年份的第一天
每年的第一天都是1 月1日,这个查询语句可以使用在存储过程中,需要对当前年份第一天做一些计算的时候。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。
?
SELECT TRUNC (SYSDATE, 'YEAR') "Year First Day" FROM DUAL;
获取当前年份的最后一天
类似于上面的查询语句。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。
?
SELECT ADD_MONTHS (TRUNC (SYSDATE, 'YEAR'), 12) - 1 "Year Last Day" FROM DUAL
获取当前月份的天数
这个语句非常有用,可以计算出当前月份的天数。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。
?
SELECT CAST (TO_CHAR (LAST_DAY (SYSDATE), 'dd') AS INT) number_of_days
? FROM DUAL;
获取当前月份剩下的天数
下面的语句用来计算当前月份剩下的天数。你可以用任何的日期值替换 “SYSDATE”来指定查询的日期。
?
SELECT SYSDATE,
? ? ? ?LAST_DAY (SYSDATE) "Last",
? ? ? ?LAST_DAY (SYSDATE) - SYSDATE "Days left"
? FROM DUAL;
获取两个日期之间的天数
使用这个语句来获取两个不同日期自检的天数。
?
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;
如果你需要查询一些特定日期的天数,可以使用第二个查询语句。这个例子是计算员工入职的天数。
?
显示当前年份截止到上个月每个月份开始和结束的日期
这个是个很聪明的查询语句,用来显示当前年份每个月的开始和结束的日期,你可以使用这个进行一些类型的计算。你可以用任何的日期值替换 “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 '.');
获取直到目前为止今天过去的秒数(从 00:00 开始算)
?
SELECT (SYSDATE - TRUNC (SYSDATE)) * 24 * 60 * 60 num_of_sec_since_morning
? FROM DUAL;
获取今天剩下的秒数(直到 23:59:59 结束)
?
SELECT (TRUNC (SYSDATE+1) - SYSDATE) * 24 * 60 * 60 num_of_sec_left
? FROM DUAL;
数据字典查询
?
检查在当前 数据库模式下是否存在指定的表
这是一个简单的查询语句,用来检查当前数据库是否有你想要创建的表,允许你重新运行创建表脚本,这个也可以检查当前用户是否已经创建了指定的表(根据这个查询语句在什么环境下运行来查询)。
?
SELECT table_name
? FROM user_tables
?WHERE table_name = 'TABLE_NAME';
检查在当前表中是否存在指定的列
这是个简单的查询语句来检查表里是否有指定的列,在你尝试使用 ALTER TABLE 来添加新的列新到表中的时候非常有用,它会提示你是否已经存在这个列。
?
SELECT column_name AS FOUND
? FROM user_tab_cols
?WHERE table_name = 'TABLE_NAME' AND column_name = 'COLUMN_NAME';
显示表结构
这 个查询语句会显示任何表的 DDL 状态信息。请注意我们已经将‘TABLE’作为第一个信息提交了。这个查询语句也可以用来获取任何数据库对象的 DDL 状态信息。举例说明,只需要把第一个参数替换成‘VIEW’,第二个修改成视图的名字,就可以查询视图的 DDL 信息了。
?
SELECT DBMS_METADATA.get_ddl ('TABLE', 'TABLE_NAME', 'USER_NAME') FROM DUAL;
获取当前模式
这是另一个可以获得当前模式的名字的查询语句。
?
SELECT SYS_CONTEXT ('userenv', 'current_schema') FROM DUAL;
修改当前模式
这是另一个可以修改当前模式的查询语句,当你希望你的脚本可以在指定的用户下运行的时候非常有用,而且这是非常安全的一个方式。
?
ALTER SESSION SET CURRENT_SCHEMA = new_schema;
数据库管理查询
?
数据库版本信息
返回 Oracle 数据库版本
?
SELECT * FROM v$version;
数据库默认信息
返回一些系统默认的信息
?
SELECT username,
? ? ? ?profile,
? ? ? ?default_tablespace,
? ? ? ?temporary_tablespace
? FROM dba_users;
数据库字符设置信息
显示数据库的字符设置信息
?
SELECT * FROM nls_database_parameters;
获取 Orac