`
zistrong
  • 浏览: 18573 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

Oracle SQL相关

阅读更多
--参数设置
v_Sql:='select count(1) from '||v_Table||' WHERE staff_id IS NULL AND UPLOAD_PROVINCE_ID=:a AND FILE_ORIG_DATE=:b';
execute immediate v_Sql into v_Count1 using i_ProvinceCode,i_OrigDate;

expgtm.sh脚本如下:
exp stat/stat@QH_BOSSSTA1 full=N tables=WORK,TASK,ROUTE rows=Y FILE=/ngbss/a.log

impgtm.sh脚本如下:
imp cen/123456@ngstatst FILE=/ngbss/gtm.dmp LOG=/ngbss/gtm.log ROWS=Y FULL=N IGNORE=Y



常用的时间格式 在oracle中有 yyyy-mm-dd hh24:mi:ss  而在Java中有些区别 为yyyy-MM-dd HH:mm:ss 这点还是经常容易模糊的。
 
相信很多人都有过统计某些数据的经历,比如,要统计财务的情况,可能要按每年,每季度,每月,甚至每个星期来分别统计。那在oracle中应该怎么来写sql语句呢,这个时候Oracle的日期函数会给我们很多帮助。

 常用日期型函数
1。Sysdate 当前日期和时间
SQL> Select sysdate from dual;

SYSDATE
----------
21-6月 -05

2。Last_day 本月最后一天 
SQL> Select last_day(sysdate) from dual;

LAST_DAY(S
----------
30-6月 -05

3。Add_months(d,n) 当前日期d后推n个月 
用于从一个日期值增加或减少一些月份 
date_value:=add_months(date_value,number_of_months)

SQL> Select add_months(sysdate,2) from dual;

ADD_MONTHS
----------
21-8月 -05

4。Months_between(f,s) 日期f和s间相差月数 
SQL> select months_between(sysdate,to_date('2005-11-12','yyyy-mm-dd'))from dual;

MONTHS_BETWEEN(SYSDATE,TO_DATE('2005-11-12','YYYY-MM-DD'))
----------------------------------------------------------
                                                -4.6966741 

5。NEXT_DAY(d, day_of_week)
返回由"day_of_week"命名的,在变量"d"指定的日期之后的第一个工作日的日期。参数"day_of_week"必须为该星期中的某一天。
SQL> SELECT next_day(to_date('20050620','YYYYMMDD'),1) FROM dual;

NEXT_DAY(T
----------
26-6月 -05

6。current_date()返回当前会话时区中的当前日期 
date_value:=current_date 
SQL> column sessiontimezone for a15 
SQL> select sessiontimezone,current_date from dual; 

SESSIONTIMEZONE CURRENT_DA 
--------------- ---------- 
+08:00          13-11月-03 
  
SQL> alter session set time_zone='-11:00' 2  / 
会话已更改。 
  
SQL> select sessiontimezone,current_timestamp from dual; 

SESSIONTIMEZONE CURRENT_TIMESTAMP 
--------------- ------------------------------------ 
-11:00          12-11月-03 04.59.13.668000 下午 -11:00 

7。current_timestamp()以timestamp with time zone数据类型返回当前会话时区中的当前日期
SQL> select current_timestamp from dual;

CURRENT_TIMESTAMP
---------------------------------------------------------------------------
21-6月 -05 10.13.08.220589 上午 +08:00

8。dbtimezone()返回时区
SQL> select dbtimezone from dual;

DBTIME
------
-08:00

9。extract()找出日期或间隔值的字段值 
date_value:=extract(date_field from [datetime_value|interval_value]) 
SQL> select extract(month from sysdate) "This Month" from dual;

This Month
----------
         6

SQL> select extract(year from add_months(sysdate,36)) " Years" from dual;

     Years
----------
      2008

10。localtimestamp()返回会话中的日期和时间 
SQL> select localtimestamp from dual;

LOCALTIMESTAMP
---------------------------------------------------------------------------
21-6月 -05 10.18.15.855652 上午

常用日期数据格式(该段为摘抄)

Y或YY或YYY 年的最后一位,两位或三位 Select to_char(sysdate,’YYY’) from dual; 002表示2002年 
SYEAR或YEAR SYEAR使公元前的年份前加一负号 Select to_char(sysdate,’SYEAR’) from dual; -1112表示公元前111 2年 
Q 季度,1~3月为第一季度 Select to_char(sysdate,’Q’) from dual; 2表示第二季度① 
MM 月份数 Select to_char(sysdate,’MM’) from dual; 12表示12月 
RM 月份的罗马表示 Select to_char(sysdate,’RM’) from dual; IV表示4月 
Month 用9个字符长度表示的月份名 Select to_char(sysdate,’Month’) from dual; May后跟6个空格表示5月 
WW 当年第几周 Select to_char(sysdate,’WW’) from dual; 24表示2002年6月13日为第24周 
W 本月第几周 Select to_char(sysdate,’W’) from dual; 2002年10月1日为第1周 
DDD 当年第几, 1月1日为001,2月1日为032 Select to_char(sysdate,’DDD’) from dual; 363 2002年1 2月2 9日为第363天 
DD 当月第几天 Select to_char(sysdate,’DD’) from dual; 04 10月4日为第4天 
D 周内第几天 Select to_char(sysdate,’D’) from dual; 5 2002年3月14日为星期一 
DY 周内第几天缩写 Select to_char(sysdate,’DY’) from dual; SUN 2002年3月24日为星期天 
HH或HH12 12进制小时数 Select to_char(sysdate,’HH’) from dual; 02 午夜2点过8分为02 
HH24 24小时制 Select to_char(sysdate,’HH24’) from dual; 14 下午2点08分为14 
MI 分钟数(0~59) Select to_char(sysdate,’MI’) from dual; 17下午4点17分 
SS 秒数(0~59) Select to_char(sysdate,’SS’) from dual; 22 11点3分22秒 
提示注意不要将MM格式用于分钟(分钟应该使用MI)。MM是用于月份的格式,将它用于分钟也能工作,但结果是错误的。 


现在给出一些实践后的用法:

1。上月末天:
SQL> select to_char(add_months(last_day(sysdate),-1),'yyyy-MM-dd') LastDay from
dual;

LASTDAY
----------
2005-05-31

2。上月今天
SQL> select to_char(add_months(sysdate,-1),'yyyy-MM-dd') PreToday from dual;


PRETODAY
----------
2005-05-21

3.上月首天
SQL> select to_char(add_months(last_day(sysdate)+1,-2),'yyyy-MM-dd') firstDay from dual;

FIRSTDAY
----------
2005-05-01

4.按照每周进行统计
SQL> select to_char(sysdate,'ww') from dual group by to_char(sysdate,'ww');

TO
--
25

5。按照每月进行统计
SQL> select to_char(sysdate,'mm') from dual group by to_char(sysdate,'mm');

TO
--
06

6。按照每季度进行统计
SQL> select to_char(sysdate,'q') from dual group by to_char(sysdate,'q');

T
-
2

7。按照每年进行统计
SQL> select to_char(sysdate,'yyyy') from dual group by to_char(sysdate,'yyyy');

TO_C
----
2005

8.要找到某月中所有周五的具体日期 
select to_char(t.d,'YY-MM-DD') from ( 
select trunc(sysdate, 'MM')+rownum-1 as d 
from dba_objects 
where rownum < 32) t 
where to_char(t.d, 'MM') = to_char(sysdate, 'MM') --找出当前月份的周五的日期 

and trim(to_char(t.d, 'Day')) = '星期五' 
-------- 
03-05-02 
03-05-09 
03-05-16 
03-05-23 
03-05-30  

如果把where to_char(t.d, 'MM') = to_char(sysdate, 'MM')改成sysdate-90,即为查找当前月份的前三个月中的每周五的日期。

9.oracle中时间运算

内容如下: 
1、oracle支持对日期进行运算 
2、日期运算时是以天为单位进行的 
3、当需要以分秒等更小的单位算值时,按时间进制进行转换即可 
4、进行时间进制转换时注意加括号,否则会出问题 

SQL> alter session set nls_date_format='yyyy-mm-dd hh:mi:ss'; 

会话已更改。 

SQL> set serverout on 
SQL> declare 
  2 DateValue date; 
  3 begin 
  4 select sysdate into DateValue from dual; 
  5 dbms_output.put_line('源时间:'||to_char(DateValue)); 
  6 dbms_output.put_line('源时间减1天:'||to_char(DateValue-1)); 
  7 dbms_output.put_line('源时间减1天1小时:'||to_char(DateValue-1-1/24)); 
  8 dbms_output.put_line('源时间减1天1小时1分:'||to_char(DateValue-1-1/24-1/(24*60))); 
  9 dbms_output.put_line('源时间减1天1小时1分1秒:'||to_char(DateValue-1-1/24-1/(24*60)-1/(24*60*60))); 
10 end; 
11 / 
源时间:2003-12-29 11:53:41 
源时间减1天:2003-12-28 11:53:41 
源时间减1天1小时:2003-12-28 10:53:41 
源时间减1天1小时1分:2003-12-28 10:52:41 
源时间减1天1小时1分1秒:2003-12-28 10:52:40 

PL/SQL 过程已成功完成。


在Oracle中实现时间相加处理
-- 名称:Add_Times
-- 功能:返回d1与NewTime相加以后的结果,实现时间的相加
-- 说明:对于NewTime中的日期不予考虑
-- 日期:2004-12-07
-- 版本:1.0
-- 作者:Kevin


create or replace function Add_Times(d1 in date,NewTime in date) return date 
is
  hh   number;
  mm   number;
  ss   number;
  hours number;
  dResult  date;  
begin
  -- 下面依次取出时、分、秒
  select to_number(to_char(NewTime,'HH24')) into hh from dual;
  select to_number(to_char(NewTime,'MI')) into mm from dual;
  select to_number(to_char(NewTime,'SS')) into ss from dual;
  -- 换算出NewTime中小时总和,在一天的百分几
  hours := (hh + (mm / 60) + (ss / 3600))/ 24;
  -- 得出时间相加后的结果
  select d1 + hours into dResult from dual;
  return(dResult);
end Add_Times;


-- 测试用例
-- select Add_Times(sysdate,to_date('2004-12-06 03:23:00','YYYY-MM-DD HH24:MI:SS')) from dual


在Oracle9i中计算时间差
计算时间差是Oracle DATA数据类型的一个常见问题。Oracle支持日期计算,你可以创建诸如“日期1-日期2”这样的表达式来计算这两个日期之间的时间差。 
   
  
一旦你发现了时间差异,你可以使用简单的技巧来以天、小时、分钟或者秒为单位来计算时间差。为了得到数据差,你必须选择合适的时间度量单位,这样就可以进行数据格式隐藏。 
  
使用完善复杂的转换函数来转换日期是一个诱惑,但是你会发现这不是最好的解决方法。 
  
round(to_number(end-date-start_date))- 消逝的时间(以天为单位) 
  
round(to_number(end-date-start_date)*24)- 消逝的时间(以小时为单位) 
  
round(to_number(end-date-start_date)*1440)- 消逝的时间(以分钟为单位) 
  
显示时间差的默认模式是什么?为了找到这个问题的答案,让我们进行一个简单的SQL *Plus查询。 
  
SQL> select sysdate-(sysdate-3) from dual; 
  
SYSDATE-(SYSDATE-3) 
------------------- 
                   3  
  
这里,我们看到了Oracle使用天来作为消逝时间的单位,所以我们可以很容易的使用转换函数来把它转换成小时或者分钟。然而,当分钟数不是一个整数时,我们就会遇到放置小数点的问题。 
  
Select 
    (sysdate-(sysdate-3.111))*1440 
from 
    dual; 
  
(SYSDATE-(SYSDATE-3.111))*1440 
------------------------------ 
                     4479.83333  
  
当然,我们可以用ROUND函数(即取整函数)来解决这个问题,但是要记住我们必须首先把DATE数据类型转换成NUMBER数据类型。 
  
Select 
    round(to_number(sysdate-(sysdate-3.111))*1440) 
from 
    dual; 
  
ROUND(TO_NUMBER(SYSDATE-(SYSDATE-3.111))*1440) 
---------------------------------------------- 
                                           4480  
  
我们可以用这些函数把一个消逝时间近似转换成分钟并把这个值写入Oracle表格中。在这个例子里,我们有一个离线(logoff)系统级触发机制来计算已经开始的会话时间并把它放入一个Oracle STATSPACK USER_LOG扩展表格之中。 
  
Update 
    perfstat.stats$user_log 
set 
    elapsed_minutes = 
    round(to_number(logoff_time-logon_time)*1440) 
where 
    user = user_id 
and 
    elapsed_minutes is NULL; 

查出任一年月所含的工作日
CREATE OR REPLACE FUNCTION Get_WorkingDays(
  ny IN VARCHAR2
) RETURN INTEGER IS
/*------------------------------------------------------------------------------------------
函数名称:Get_WorkingDays
中文名称:求某一年月中共有多少工作日
作者姓名: XINGPING
编写时间: 2004-05-22
输入参数:NY:所求包含工作日数的年月,格式为yyyymm,如200405
返 回 值:整型值,包含的工作日数目。
算法描述:
    1).列举出参数给出的年月中的每一天。这里使用了一个表(ljrq是我的库中的一张表。这个表可以是有权访问的、记录条数至少为31的任意一张表或视图)来构造出某年月的每一天。
    2).用这些日期和一个已知星期几的日期相减(2001-12-30是星期天),所得的差再对7求模。如果所求年月在2001-12-30以前,那么所得的差既是负数,求模后所得值范围为大于-6,小于0,如-1表示星期六,故先将求模的结果加7,再求7的模.
    3).过滤掉结果集中值为0和6的元素,然后求count,所得即为工作日数目。      
-------------------------------------------------------------------------------------------------*/
  Result INTEGER;
BEGIN
  SELECT COUNT(*) INTO Result
    FROM (SELECT MOD(MOD(q.rq-to_date('2001-12-30','yyyy-mm-dd'),7),7) weekday
            FROM ( SELECT to_date(ny||t.dd,'yyyymmdd') rq
                     FROM (SELECT substr(100+ROWNUM,2,2) dd 
                             FROM ljrq z WHERE Rownum<=31
                          ) t
                     WHERE to_date(ny||t.dd,'yyyymmdd') 
                       BETWEEN to_date(ny,'yyyymm') 
                           AND last_day(to_date(ny,'yyyymm'))
                 )q
         ) a   
    WHERE a.weekday NOT IN(0,6);    
  RETURN Result;  
END Get_WorkingDays;

______________________________________

还有一个版本
CREATE OR REPLACE FUNCTION Get_WorkingDays(
  ny IN VARCHAR2
) RETURN INTEGER IS
/*-----------------------------------------------------------------------------------------
函数名称:Get_WorkingDays
中文名称:求某一年月中共有多少工作日
作者姓名: XINGPING
编写时间: 2004-05-23
输入参数:NY:所求包含工作日数的年月,格式为yyyymm,如200405
返 回 值:整型值,包含的工作日数目。
算法描述:使用Last_day函数计算出参数所给年月共包含多少天,根据这个值来构造一个循环。在这个循环中先求这个月的每一天与一个已知是星期天的日期(2001-12-30是星期天)的差,所得的差再对7求模。如果所求日期在2001-12-30以前,那么所得的差既是负数,求模后所得值范围为大于-6,小于0,如-1表示星期六,故先将求模的结果加7,再求7的模. 如过所得值不等于0和6(即不是星期六和星期天),则算一个工作日。      
----------------------------------------------------------------------------------------*/
  Result INTEGER := 0;
  myts INTEGER;      --所给年月的天数
  scts INTEGER;      --某天距2001-12-30所差的天数
  rq   DATE;
  djt INTEGER := 1;   -- 
BEGIN
  myts := to_char(last_day(to_date(ny,'yyyymm')),'dd');  
  LOOP 
    rq := TO_date(ny||substr(100+djt,2),'yyyymmdd');
    scts := rq - to_date('2001-12-30','yyyy-mm-dd');
    IF MOD(MOD(scts,7)+7,7) NOT IN(0,6) THEN
      Result := Result + 1;
    END IF;
    djt := djt + 1;  
    EXIT WHEN djt>myts;
  END LOOP;  
  RETURN Result;  
END Get_WorkingDays;

以上两个版本的比较

第一个版本一条SQL语句就可以得出结果,不需要编程就可以达到目的。但需要使用任意一张有权访问的、记录条数至少为31的一张表或视图。
    第二个版本需要编程,但不需要表或者视图。
    这两个版本都还存在需要完善的地方,即没有考虑节日,如五一、十一、元旦、春节这些节假期都没有去除。这些节假日应该维护成一张表,然后通过查表来去除这些节假日。


select userenv('language') from dual;



declare 
  col_name VARCHAR(50);
  col_type VARCHAR(20);
  all_cols VARCHAR(2000);
  CURSOR col_cur IS select * from all_tab_cols where table_name ='TF_B_PAYLOG_CENTER' AND owner ='APP' order by segment_column_id;
BEGIN

  all_cols := '';
  FOR v_cur IN col_cur 
   LOOP
      col_name := v_cur.column_name;
      col_type := v_cur.data_type;
      if v_cur.data_type = 'DATE' then
       col_name := 'to_char('|| col_name || ',''yyyymmddhh24miss'')';
      end if;
      
      all_cols :=all_cols || col_name || ' || ' || 'chr(01)' || ' || ';
      
   END LOOP;
   dbms_output.put_line(all_cols);
end;


#查看那ORACLE实例
select instance_name from v$instance;

select force_logging from v$database;



  create table tf_f_user_item_bi tablespace TBS_CRM_DEF as select * from uop_crm3.tf_f_user_item t;



  两台不同的数据库服务器,从一台数据库服务器的一个用户读取另一台数据库服务器下的某个用户的数据,这个时候可以使用dblink。

  其实dblink和数据库中的view差不多,建dblink的时候需要知道待读取数据库的ip地址,ssid以及数据库用户名和密码。

  创建可以采用两种方式:

  1、已经配置本地服务

 

    以下是引用片段:
  create public database 
  link dl_crm12act1 connect to fzept 
  identified by neu using 'fjept'
  CREATE DATABASE LINK 数据库链接名 CONNECT TO 用户名 IDENTIFIED BY 密码 USING '本地配置的数据的实例名';

  2、未配置本地服务

  

      以下是引用片段:
     create database link linkfwq 
   connect to fzept identified by neu 
   using '(DESCRIPTION = 
   (ADDRESS_LIST = 
   (ADDRESS = (PROTOCOL = TCP)(HOST = 10.142.202.12)(PORT = 1521)) 
   ) 
   (CONNECT_DATA = 
   (SERVICE_NAME = fjept) 
   ) 
   )';
  host=数据库的ip地址,service_name=数据库的ssid。
  其实两种方法配置dblink是差不多的,我个人感觉还是第二种方法比较好,这样不受本地服务的影响。

  数据库连接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定义.

  数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样

  数据库全局名称可以用以下命令查出

  SELECT * FROM GLOBAL_NAME;

  查询远端数据库里的表

  SELECT …… FROM 表名@数据库链接名;

  查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成“表名@dblink服务器”而已。

  附带说下同义词创建:

  CREATE SYNONYM同义词名FOR 表名;

  CREATE SYNONYM同义词名FOR 表名@数据库链接名;

  删除dblink:DROP PUBLIC DATABASE LINK linkfwq。

  如果创建全局dblink,必须使用systm或sys用户,在database前加public。


tnsping  service_name


--月份处理
SELECT Trunc(Trunc(SYSDATE, 'MONTH') - 1, 'MONTH') First_Day_Last_Month,
       Trunc(SYSDATE, 'MONTH') - 1 / 86400 Last_Day_Last_Month,
       Trunc(SYSDATE, 'MONTH') First_Day_Cur_Month,
       LAST_DAY(Trunc(SYSDATE, 'MONTH')) + 1 - 1 / 86400 Last_Day_Cur_Month
  FROM dual;

oerr ORA 1555

--查找使用频繁的资源
select *
  from (select sql_text, executions, buffer_gets, disk_reads
          from v$sqlarea
         order by buffer_gets)
 where rownum < 51;


SELECT UPPER(D.TABLESPACE_NAME) "表空间名",
       D.TOT_GROOTTE_MB "表空间大小(M)",
       D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",
       TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,
                     2),
               '990.99') "使用比",
       F.TOTAL_BYTES "空闲空间(M)",
       F.MAX_BYTES "最大块(M)"
  FROM (SELECT TABLESPACE_NAME,
               ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
               ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
          FROM SYS.DBA_FREE_SPACE
         GROUP BY TABLESPACE_NAME) F,
       (SELECT DD.TABLESPACE_NAME,
               ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB
          FROM SYS.DBA_DATA_FILES DD
         GROUP BY DD.TABLESPACE_NAME) D
 WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME(+)
 --and  UPPER(D.TABLESPACE_NAME) like '%I%'
 ORDER BY 4 DESC;  



select * from v$db_object_cache where type='PROCEDURE';


SELECT t.* FROM v$session  t WHERE username = 'UIF_CRM1_BI';



-- 分区表
create table TD_S_EXELOG
(
  partition_id NUMBER(2) default TO_NUMBER(TO_CHAR(SYSDATE,'MM')) not null,
  work_id      NUMBER(6) not null,
  task_id      NUMBER(6) not null,
  exe_date     VARCHAR2(16),
  next_date    VARCHAR2(16),
  err_code     NUMBER(6),
  err_info     VARCHAR2(200),
  this_date    VARCHAR2(16),
  run_number   NUMBER(6),
  plug_name    VARCHAR2(80)
)
partition by range (PARTITION_ID)
(
  partition PAR_TD_S_EXELOG_01 values less than (2),
  partition PAR_TD_S_EXELOG_02 values less than (3),
  partition PAR_TD_S_EXELOG_03 values less than (4),
  partition PAR_TD_S_EXELOG_04 values less than (5),
  partition PAR_TD_S_EXELOG_05 values less than (6),
  partition PAR_TD_S_EXELOG_06 values less than (7),
  partition PAR_TD_S_EXELOG_07 values less than (8),
  partition PAR_TD_S_EXELOG_08 values less than (9),
  partition PAR_TD_S_EXELOG_09 values less than (10),
  partition PAR_TD_S_EXELOG_10 values less than (11),
  partition PAR_TD_S_EXELOG_11 values less than (12),
  partition PAR_TD_S_EXELOG_12 values less than (MAXVALUE)
);
-- Create/Recreate indexes 
create index IDX_TD_S_EXELOG_WORK_ID on TD_S_EXELOG (WORK_ID, THIS_DATE, PARTITION_ID);


--复制表
COPY FROM UCR_CRM1/UCR_CRM1@SICRM1DB TO UOP_ACT1/UOP_ACT1@SIACT1DB REPLACE TD_CHL_KINDDEF USING SELECT * FROM TD_CHL_KINDDEF;
COPY FROM UCR_CRM1/UCR_CRM1@SICRM1DB TO UOP_ACT1/UOP_ACT1@SIACT1DB REPLACE TF_CHL_CHANNEL USING SELECT * FROM TF_CHL_CHANNEL;

--树
SELECT CHNL_ID FROM TF_CHL_CHANNEL D
                 START WITH D.PARENT_DEPART_ID = '00000'
                CONNECT BY PRIOR D.CHNL_ID = D.PARENT_DEPART_ID;

--数据库信息
SELECT * FROM v$database t;


--查找存储过程
SELECT T.*
  FROM ALL_PROCEDURES T
 WHERE T.OBJECT_NAME = 'P_ITF_BST_USERTABINFO_THREE';

--SQLLDR
load data
infile *
Append into table test
replace
fields terminated by WHITESPACE
optionally enclosed by '"'
(field1 constant 9999,field2 RECNUM,field3 )
BEGINDATA
aaaa
bbbb



--查询死锁情况
select decode(request,0,'Holder:','Waiter:') || sid,id1,id2,TYPE 
FROM v$lock a 
where (id1,id2,type) in (select id1,id2,type from v$lock where request>0);

--随机获取数据库中的一条记录,全表扫描,很慢
SELECT SYSID
  FROM (SELECT SYSID FROM UIP_TD_M_SVCMAP ORDER BY DBMS_RANDOM.VALUE)
 WHERE ROWNUM = 1

EXISTS与IN的使用效率的问题,通常情况下采用exists要比in效率高,因为IN不走索引,但要看实际情况具体使用:
IN适合于外表大而内表小的情况;EXISTS适合于外表小而内表大的情况。


--查找重复记录
SELECT *
  FROM TD_S_ROUTE A
 WHERE ROWID !=
       (SELECT MAX(ROWID)   FROM TD_S_ROUTE B WHERE A.WORK_ID = B.WORK_ID AND A.START_TASK_ID = B.START_TASK_ID AND A.END_TASK_ID = B.END_TASK_ID);
DELETE FROM TD_S_ROUTE A
 WHERE ROWID !=
       (SELECT MAX(ROWID)   FROM TD_S_ROUTE B WHERE A.WORK_ID = B.WORK_ID AND A.START_TASK_ID = B.START_TASK_ID AND A.END_TASK_ID = B.END_TASK_ID);

--表分析
analyze table    表名 compute statistics
analyze index 索引ID compute statistics


SELECT O.SID, OSUSER, MACHINE, COUNT(*) NUM_CURS
  FROM V$OPEN_CURSOR O, V$SESSION S
 WHERE USER_NAME = 'UOP_CRM1'
   AND O.SID = S.SID
 GROUP BY O.SID, OSUSER, MACHINE
 ORDER BY NUM_CURS DESC;


select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id;



select b.username,b.sid,b.serial#,logon_time 
from v$locked_object a,v$session b
where a.session_id = b.sid order by b.logon_time;

 alter system kill session 'sid,serial#';

alter system kill session '29,5497' immediate;





关于 pl/sql developer中 timestamp时间类型显示中包含 "上午"的解决方法:

右击我的电脑, 属性 => 高级. 新增系统环境变量.

名称: NLS_TIMESTAMP_FORMAT

值: YYYY-MM-DD HH24:MI:SS:FF6

保存后, 重启pl/sql developer即可.



--定时任务
BEGIN
  
  DBMS_JOB.remove(279);
END;
/

commit;

VARIABLE V_JOB_NO NUMBER;
BEGIN
  DBMS_JOB.Submit(:V_JOB_NO,
                  'PRO_CIRCLE_DEL_OVERDUE;',
                  TRUNC(SYSDATE + 1 )+ 1 / 48,
                  'trunc(sysdate+1)+1/48');
END;
/

commit;


ALTER TABLE T_LLBSHOP_GIFT ADD CONSTRAINT CMK_T_LLBSHOP_GIFT_STOCK CHECK(GIFT_STOCK <> 0);



declare  

  v_pname user_tab_partitions.partition_name%type;
  v_part_maxval test.x%type;
  type tab_type is table of test.x%type 
    index by pls_integer;
  v_cnt tab_type;

begin

  select partition_name
           into v_pname
  from user_tab_partitions
  where table_name='TEST' and 
        partition_position=
                           (
                             select max(partition_position)-1
                             from user_tab_partitions
                             where table_name='TEST'
                           );
                           
  execute immediate 'select max(x) from test partition('
                    ||v_pname
                    ||')' 
          into v_part_maxval;

  select distinct round(x/100)
           bulk collect into v_cnt
  from test
  where x>v_part_maxval order by 1;

  for i in 1..v_cnt.count loop
  dbms_output.put_line(v_cnt(i));

    execute immediate 'ALTER TABLE test
                       SPLIT PARTITION part_other AT ('
                       ||v_cnt(i)
                       ||'01)'
                       ||'INTO (PARTITION part_'
                       ||v_cnt(i)
                       ||'00,PARTITION part_other)
                       UPDATE GLOBAL INDEXES'; 
  end loop;

end;


--修改空闲连接回收时间
 create a profile
  create profile profile1 limit idle_time 60;
 alter user use this profile
  alter user username profile profile1;
 enale resource limit by
  alter system set resource_limit=true;
  or shutdown database and modify init.ora resource_limit= true then start database


--表空间
SELECT DBA_TABLES.OWNER,
       DBA_TABLES.TABLESPACE_NAME,
       DBA_TABLES.TABLE_NAME,
       ROUND(SUM(BYTES) / 1024 / 1024 / 1024, 6) GIGS
  FROM SYS.DBA_EXTENTS, SYS.DBA_TABLES
 WHERE ((DBA_TABLES.TABLESPACE_NAME = DBA_EXTENTS.TABLESPACE_NAME) AND
       (DBA_TABLES.OWNER = UPPER('&owner')))
 GROUP BY DBA_TABLES.OWNER,
          DBA_TABLES.TABLESPACE_NAME,
          DBA_TABLES.TABLE_NAME
HAVING ROUND(SUM(BYTES) / 1024 / 1024 / 1024, 6) > &SIZE_IN_GIGS





--meger

MERGE INTO PRODUCTS P
USING (SELECT 345 AS A FROM DUAL) NP
ON (P.PRODUCT_ID = NP.A)
WHEN NOT MATCHED THEN
  INSERT
    (PRODUCT_ID, PRODUCT_NAME, CATEGORY)
  VALUES
    ('345', 'ddd', 'ssss');


--外键
 select * from user_constraints T WHERE t.CONSTRAINT_TYPE='R';

--表大小
SELECT t.*,round(t.BYTES/1024/1024,2)||'M' from user_segments t /*WHERE t.segment_type='TABLE' */ORDER BY t.BYTES DESC;


--索引大小
SELECT A.TABLE_NAME,
       A.COLUMN_NAME,
       B.SEGMENT_NAME,
       B.SEGMENT_TYPE,
       B.TABLESPACE_NAME,
       B.BYTES / 1024 / 1024,
       B.BLOCKS,
       B.EXTENTS
  FROM USER_LOBS A, USER_SEGMENTS B
 WHERE A.SEGMENT_NAME = B.SEGMENT_NAME
 ORDER BY B.BYTES DESC;



--执行存储过程
DECLARE
  RESULT NUMBER(1);
  MSG    VARCHAR2(100);
BEGIN

  PRO_CB_SYNC_BUSIINFO(CYCLE => &1, RESULT => RESULT, MSG => MSG);
  dbms_output.put_line(msg);
END;
/


--plsq中的全局变量  
  SQLERRM
  SQLCODE

 

分享到:
评论

相关推荐

    oracle SQL查询工具

    oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具oracle SQL查询工具...

    Oracle Sql语句转换成Mysql Sql语句

    在数据库管理领域,Oracle SQL和MySQL SQL是两种广泛使用的SQL方言,它们在语法和功能上存在一定的差异。当需要将一个基于Oracle SQL的应用程序迁移到MySQL环境时,就需要进行SQL语句的转换工作。本项目提供了一个...

    Oracle SQL高级编程

    由于标题和描述是重复的且没有提供实质性的内容,我们无法从中得知具体的Oracle SQL高级编程知识点。但是,从标题我们可以推测该文档可能是关于如何使用Oracle数据库中的SQL语言进行高级编程。Oracle数据库是一个...

    Oracle Sql基础(beginning oracle sql中文版)

    Oracle SQL是数据库管理员和开发人员用来与Oracle数据库交互的语言,它是SQL标准的扩展,提供了许多特有的功能和优化。本资源“Oracle Sql基础(beginning oracle sql中文版)”旨在为初学者提供一个全面的Oracle ...

    Oracle SQL 官方文档

    Oracle SQL 是一种强大的数据库查询和编程语言,广泛用于管理和操作Oracle数据库系统。11g第二版(11G2)是Oracle的一个重要版本,提供了许多增强功能和优化。本官方文档集包括四份重要的参考资料,涵盖了Oracle SQL...

    Oracle SQL必备参考.pdf 高清下载

    并未直接提供关于Oracle SQL的具体信息,但从标题和描述“Oracle SQL必备参考.pdf 高清下载”中,我们可以推断出文档可能涵盖的关键知识点与Oracle SQL相关。因此,下面将详细介绍与Oracle SQL相关的几个重要知识点...

    OracleSQLDeveloper

    Oracle SQL Developer 是一款由Oracle公司推出的免费数据库管理工具,它为数据库管理员(DBA)和开发人员提供了一个全面的集成环境,以便于管理和操作Oracle数据库。这个工具的强大之处在于其直观的用户界面和广泛的...

    Oracle-SQL.rar_oracle_oracle sql_sql

    在“Oracle-SQL.rar”这个压缩包中,包含了一份名为“Oracle SQL.ppt”的文件,这可能是一个PowerPoint演示文稿,用于详细讲解Oracle数据库的基础知识和SQL语言的使用。下面,我们将深入探讨一些Oracle SQL的基础...

    精通 ORACLE SQL高级编程 学习笔记

    精通Oracle SQL【第2版】ORACLE SQL高级编程【第二版】学习笔记

    Oracle SQL Developer 使用说明

    Oracle SQL Developer 是一款由Oracle公司推出的强大的数据库管理工具,它为数据库管理员(DBA)、开发者以及数据分析师提供了全面的功能,以高效地管理和操作Oracle数据库。本文档将深入讲解Oracle SQL Developer的...

    ORACLE_SQLDeveloper使用教程

    ### Oracle SQL Developer 使用教程 #### 一、Oracle Database Home Page 的使用 在开始介绍 Oracle SQL Developer 的使用之前,我们先来看看如何使用...希望这些知识能够帮助您更好地理解和使用 Oracle 相关的工具。

    记使用Oracle SQL Developer 迁移MySql 数据至 Oracle.docx

    本文将详细讲解如何使用Oracle SQL Developer工具进行这样的迁移过程,以及如何解决在迁移过程中遇到的问题。 首先,确保你拥有正确的工具。在这个案例中,你需要MySQL 5.6.37、Oracle 11g以及Oracle SQL Developer...

    精通OracleSQL第2版.zip

    《精通Oracle SQL(第2版)》是一本深入解析Oracle数据库查询语言的专业书籍,由Oracle ACE和OakTable团队的专家共同撰写,集成了他们的丰富经验和专业知识。这本书旨在帮助读者掌握Oracle SQL的高级技巧,提升在...

    Oracle SQL 内置函数大全

    Oracle SQL 内置函数大全 SQL中的单记录函数 给出整数,返回对应的字符 连接两个字符串 增加或减去月份 用于对查询到的结果进行排序输出

    Oracle四大宝典之一:Oracle Sql基础 中文版

    第三章 ORACLE SQL 单行函数 第四章 从多表中查询数据 第五章 用组函数合计数据 第六章 子查询 第七章 操纵数据 第八章 创建和管理表 第九章 内置约束 第十章 创建视图 第十一章 其他数据库对象 第十二章 控制用户...

    OracleSQL的优化.pdf

    Oracle SQL 优化 Oracle SQL 优化是数据库性能优化的关键部分。为了提高数据库的性能,我们需要从五个方面进行调整:去掉不必要的大型表的全表扫描、缓存小型表的全表扫描、检验优化索引的使用、检验优化的连接技术...

    OracleSQL必备参考

    14. **数据字典**:Oracle的数据字典存储有关数据库对象的信息,如表、列、索引等。通过查询数据字典视图,用户可以获取数据库的相关元数据。 以上只是Oracle SQL部分核心概念的概述。实际使用中,还需要熟悉SQL...

    Oracle的SQL监视工具SQLTracker

    Oracle的SQL监视工具SQLTracker是一款强大的性能分析工具,专为数据库管理员和开发人员设计,用于诊断和优化SQL查询性能。这款工具在Oracle数据库环境中扮演着重要角色,它可以帮助用户实时监控SQL语句的执行情况,...

Global site tag (gtag.js) - Google Analytics