Oracle入门

中文字符集环境变量

NLS_LANG = SIMPLIFIED CHINESE_CHINA.ZHS16GBK

当前连接oracle客户端IP

select sys_context('userenv', 'ip_address') from dual

查看当前容器

select sys_context('USERENV', 'CON_NAME') from dual;

查看版本

select * from v$version;

clob模糊查询

dbms_lob.instr(raw_data, '陈独秀', 1, 1) > 0;
SELECT * FROM table_name WHERE dbms_lob.instr(clob_column, 'search_string') > 0;

创建表空间 ORACLE_DATA

create tablespace ORACLE_DATA datafile '/home/oracle/app/oracle/oradata/mydata/ORACLE_DATA_1.DBF' size 128M autoextend on next 32m;
# 扩展表空间 HISDATA
alter tablespace ORACLE_DATA add datafile '/home/oracle/app/oracle/oradata/mydata/ORACLE_DATA_2.DBF' size 128M autoextend on next 32m;

创建用户 gyzl , 密码 gyzl123

create user gyzl
identified by gyzl123
default tablespace ORACLE_DATA
temporary tablespace TEMP;
-- Grant/Revoke role privileges 
grant resource to gyzl;
grant dba to gyzl;
grant connect to gyzl;
-- Grant/Revoke system privileges 
grant unlimited tablespace to gyzl;

连接串

Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=10.1.202.67)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)));User Id=his;Password=his

用户密码不过期

--查看用户的proifle是哪个,一般是DEFAULT
SELECT username,PROFILE FROM dba_users;
--查看对应的概要文件(如DEFAULT)的密码有效期设置
SELECT * FROM dba_profiles s WHERE s.profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';
--将概要文件(如DEFAULT)的密码有效期由默认的180天修改成"无限制"
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;

sqlplus 连接远程数据库

sqlplus user/password@//ip:port/orcl as sysdba

auto replase

up=update
se=select
fr=from
wh=where
ob=order by
gb=group by
de=delete
ex=exists
df=delete from
sf=select * from
stf=select t.*,rowid from
sc=select count(*) from
sfu=select * from for update
cor=create or replace
pro=procedure
fn=function
sso=set serveroutput on


Oracle高级

查询所有表实际行数

declare
  l_count  number := 0;
begin
  DBMS_OUTPUT.ENABLE(buffer_size => null); --输出不会出错
  for x in (select ut.table_name from dba_tables ut where ut.OWNER = 'HIS'  order by ut.TABLE_NAME) loop
    begin
        execute immediate 'select count(0) from ' || x.table_name into l_count;
        dbms_output.put_line(x.table_name||'----'||l_count);
    exception
      when others then
        dbms_output.put_line('ERROR_'||x.table_name);
    end;
  end loop;
end;

导出指定表指定行数

exp test/test@127.0.0.1/orcl file=t.dmp tables=(table1,table2) query="'where rownum<=10000'"

所有空表初始化表空间通过exp才能导出

declare
begin
  for x in (select 'alter table ' ||table_name ||' allocate extent' sss from user_tables where segment_created='NO' ) loop
    begin
      execute immediate x.sss;
    end;
  end loop;
end;

查询每个表实际占用空间

select ut.table_name,ut.OWNER,ut.tablespace_name,num_rows,us.BYTES from dba_tables ut,(select segment_name,sum(bytes)/1024/1024 bytes 
from user_segments group by segment_name) us 
where ut.TABLE_NAME = us.segment_name
order by num_rows desc nulls last ;

修改oracle字符集

sqlplus / as sysdba
select userenv('language') from dual;
shutdown immediate;
startup mount;
alter system enable restricted session;
alter system set JOB_QUEUE_PROCESSES=0;
alter system set AQ_TM_PROCESSES=0;
alter database open;
alter database character set INTERNAL_USE ZHS16GBK;
shutdown immediate;
startup;

查询用户下每张表备注以及字段备注

select ATC.OWNER,
       atC.TABLE_NAME,
       utc.comments,
       ATC.COLUMN_NAME,
       ATC.DATA_TYPE,
       ATC.DATA_LENGTH,
       ATC.NULLABLE,
       ucc.comments
  from (select ATC.OWNER,
               atC.TABLE_NAME,
               ATC.COLUMN_NAME,
               ATC.DATA_TYPE,
               ATC.DATA_LENGTH,
               ATC.NULLABLE
          from all_tab_columns ATC
         where ATC.owner in ('HIS')) atc
  left outer join user_col_comments ucc
    on atc.table_name = ucc.table_name
   and atc.column_name = ucc.column_name
  left outer join user_tab_comments utc
    on atc.table_name = utc.table_name
 order by atc.table_name, atc.column_name;

数据闪回

select * from table1 as of timestamp to_timestamp('2010-01-09 10:00:45','YYYY-MM-DD HH24:MI:SS')

设置密码输错无限次数

select * from dba_profiles;
alter profile default limit FAILED_LOGIN_ATTEMPTS UNLIMITED;

临时表查询

with tableTemp as(select * from dual)
select from table1 a,tableTemp b where a.id=b.id

多行拼接成一行

select to_char(wm_concat(table1.name)) from table1

锁表解锁

Lock_mode
0:none
1:null 空
2:Row-S 行共享(RS):共享表锁,sub share
3:Row-X 行独占(RX):用于行的修改,sub exclusive
4:Share 共享锁(S):阻止其他DML操作,share
5:S/Row-X 共享行独占(SRX):阻止其他事务操作,share/sub exclusive
6:exclusive 独占(X):独立访问使用,exclusive

--普通锁
SELECT 'alter system kill session '''||s.sid||','||s.serial#||''';' kill_session, 
       s.sid,
       s.serial#,
       o.object_name,
       s.machine,
       l.LOCKED_MODE,
       l.os_user_name,
       s.PROGRAM,
       s.ACTION,
       s.CLIENT_INFO,
       s.LOGON_TIME
  FROM gv$locked_object l, dba_objects o, gv$session s
 WHERE l.object_id = o.object_id(+)
   AND l.session_id = s.sid(+)
 ORDER BY to_number(s.SID);

--RAC服务锁
select decode(l.request, 0, 'Holder:   ', '  Waiter: ') || l.inst_id || ':' ||
       l.sid sess,
       l.id1,
       l.id2,
       l.lmode,
       l.request,
       l.type,
       l.ctime,
       a.event,
       s.sql_text,
       a.sql_id,
       a.program,
       a.CLIENT_INFO,
       'alter system kill session ''' || a.sid || ',' || a.serial# || ',@' ||
       a.inst_id || ''' immediate ;' kill_session
  from gv$lock l, gv$session a, v$sqlarea s, gv$process p
 where (l.id1, l.id2, l.type) in
       (select id1, id2, type from gv$lock where request > 0)
   and l.sid = a.sid --and l.SID in ('1782')
   and l.inst_id = a.inst_id
   and a.inst_id = p.inst_id
   and a.sql_id = s.sql_id(+)
   and a.paddr = p.addr(+)
 order by l.id1, l.request, l.ctime;

配置监听

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = CLRExtProc)
      (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1)
      (PROGRAM = extproc)
      (ENVS = "EXTPROC_DLLS=ONLY:D:\app\Administrator\product\11.2.0\dbhome_1\bin\oraclr11.dll")
    )
	(SID_DESC =
       (GLOBAL_DBNAME = orcl)
       (ORACLE_HOME = D:\app\Administrator\product\11.2.0\dbhome_1)   
       (SID_NAME = orcl)
    )
  )
LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
    )
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = WIN-8CD225QHBAK)(PORT = 1521))
    )
	(DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.202.38)(PORT = 1521))
    )
  )
ADR_BASE_LISTENER = D:\app\Administrator

触发器

登录的时候存ip

/*登录的时候存ip==>gv$session.client_info*/
create or replace trigger trg_login_on after logon on database
begin
  dbms_application_info.set_client_info(sys_context('userenv', 'ip_address'));
end;

存储过程

重置 seq 为 MinValue

create or replace procedure prc_reset_seq(v_seqname varchar2) as
/*重置 seq 为 MinValue, 不是Cycle的只能重置为MinValue + increment*/
  n number(10);
begin
  execute immediate 'select ' || v_seqname || '.nextval from dual' into n;
  execute immediate 'alter sequence ' || v_seqname || ' increment by ' || -n;
  begin
    execute immediate 'select ' || v_seqname || '.nextval from dual' into n;
  exception when others then--不是Cycle会出错
    execute immediate 'alter sequence ' || v_seqname || ' increment by ' || (1-n);-- -(n-1)  or -n+1
    execute immediate 'select ' || v_seqname || '.nextval from dual' into n;
  end;
  execute immediate 'alter sequence ' || v_seqname || ' increment by 1';
end prc_reset_seq;

文章作者: Captain
版权声明: 本站所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 One piece
学习笔记
喜欢就支持一下吧