==========================死锁查询及解锁======================= 1 检查死锁的表 SELECT substr(v$lock.sid,1,4) "SID", substr(username,1,12) "UserName", substr(object_name,1,25) "ObjectName", v$lock.type "LockType", decode(rtrim(substr(lmode,
==========================死锁查询及解锁=======================
1 检查死锁的表
SELECT substr(v$lock.sid,1,4) "SID",
substr(username,1,12) "UserName",
substr(object_name,1,25) "ObjectName",
v$lock.type "LockType",
decode(rtrim(substr(lmode,1,4)),
'2','Row-S (SS)','3','Row-X (SX)',
'4','Share', '5','S/Row-X (SSX)',
'6','Exclusive', 'Other' ) "LockMode",
substr(v$session.program,1,25) "ProgramName",
v$session.SERIAL#,
'alter system kill session ' || v$session.SERIAL#
FROM V$LOCK,SYS.DBA_OBJECTS,V$SESSION
WHERE (OBJECT_ID = v$lock.id1
AND v$lock.sid = v$session.sid
AND username IS NOT NULL
AND username NOT IN ('SYS','SYSTEM')
AND SERIAL# != 1)
2 找到表对应的session
select 'alter system kill session ''' || a.sid || ',' || b.serial# || ''';'
from v$lock a, all_objects c, v$session b
where a.sid > 8
and a.id1 = c.object_id
and a.sid = b.sid and (a.SID= '773' or a.SID= '775')
3 杀掉相应的进程
alter system kill session 'sid,serial#';
=================================================================
--详细的列出每个表的占用情况
SELECT a.tablespace_name ,
ROUND(SUM(a.bytes)/1024/1024/1024,2) "GB",
ROUND((SUM(a.bytes)-SUM(nvl(b.bytes,0)))/1024/1024/1024,2) "Used",
ROUND(SUM(nvl(b.bytes,0))/1024/1024/1024,2) "Free"
FROM dba_data_files a, dba_free_space b
WHERE a.file_id=b.file_id(+)
AND a.tablespace_name=b.tablespace_name
GROUP BY a.tablespace_name
ORDER BY a.tablespace_name
---空间使用比
select a.tablespace_name,ROUND(a.bytes/1024/1024/1024) "Sum GB",ROUND((a.bytes-b.bytes)/1024/1024/1024) "used GB",ROUND(b.bytes/1024/1024/1024) "free GB",
round(((a.bytes-b.bytes)/a.bytes)*100,2) "percent_used"
from
(select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest from dba_free_space group by tablespace_name) b
where a.tablespace_name=b.tablespace_name
order by ((a.bytes-b.bytes)/a.bytes) desc
===============================SQL语句用法=====================
1 修改某个表的字段的数据类型
alter table tb_b_dm_cdma_dev_prf modify brand_type_id number(10);
2 清空指定分区记录
ALTER TABLE TB_B_FT_DAY_CHARGE_200811 TRUNCATE PARTITION platn_551
3 增加约束
ALTER TABLE tb_jtsc_data_comp ADD CONSTRAINT supplier_unique UNIQUE (supplier_id);
4 alter table tb_cw_auto_file_config modify comp_tab not null ; Table altered
5 alter table tb_cw_auto_file_config add constraint p_rule_id primary key(rule_id);
6 alter table TB_B_FT_OFR_REV_DM_200904 add SYS_USER_TYPE_ID NUMBER(6);
-- Add comments to the columns
comment on column TB_B_FT_OFR_REV_DM_200904.SYS_USER_TYPE_ID
is '系统用户标识 tb_b_dim_sys_user_type ';
7 增加分区
ALTER TABLE TB_B_FT_BILL_BUSI_MONTH ADD PARTITION P200903 VALUES LESS THAN (200904) TABLESPACE TBS_BIL_OTHER;
截断分区:alter table sales truncate partiton sales1999_q2;
8 给表建立索引
create index ind_jtsc_edp_21 on tb_jtsc_edp_21_mid (acct_item_type_id) tablespace TBS_IND_ACCT_ITEM_550 ;
======================增加表空间==================
1 lsvg -l 找到有空余的空间 必须是close的
2
alter tablespace TBS_BSS_REV_MONTH_00 add datafile '/dev/rdw_sett_795' reuse ; 里面要加个r
========================oracle的记录删除恢复========
1 将删除的表给 恢复了
flashback table tablename to before drop;但是oracle可能会提示在oracle的recyclebin中没有此表的 错误提示信息
2 闪回查询
首先 执行alter table table_name enable row movement(必须保证该表row movement);
然后闪回到某个时间点上
flashback table test_flashback to timestamp
to_timestamp('2008-10-13 16:47:00','YYYY-MM-DD HH24:MI:SS')
也可以
select * from test_flashback as of timestamp
to_timestamp('2008-10-13 16:47:00','YYYY-MM-DD HH24:MI:SS')
col scn for 9999999999999
select timestamp_to_scn('14-10月 -08 10.40.00.000000000 上午') from dual;
select scn_to_timestamp(9450968440129) scn from dual;
insert into tb_evt_cust_order_tr_551 select * from tb_evt_cust_order_tr_551 as of timestamp scn_to_timestamp(9450968440129) where order_id ='32620094';
select timestamp_to_scn(to_timestamp('2008-10-30 13:46:04 ','yyyy-mm-dd hh24:mi:ss'))
from dual;
select timestamp_to_scn(to_timestamp('2008-11-04 16:50:00','YYYY-MM-DD HH24:MI:SS')) from dual;
select * from tb_check_e6e8_prf_bak_e8 as of
scn 9459341319432
用以下语句可以查询到每个操作的时间 versions_starttime 字段
select versions_starttime,
versions_endtime,
versions_xid,
versions_operation
from 被删除的表名 versions between timestamp minvalue and maxvalue
order by versions_starttime;
3 如果误删除了记录,将其恢复步骤如下
1 alter table tb_check_e6e8_prf_bak_e8 enable row movement;(这个命令的作用是,允许Oracle 修改分配给 行的rowid。在Oracle 中,插入一行时就会为它分配一个rowid,而且这一行永远拥有这个rowid。闪回表处理会对EMP 完成DELETE,并且重新插入行,这样就会为这些行分配一个新的rowid。要支持闪回就必须允许Oracle 执行这个操作)
2 flashback table tb_check_e6e8_prf_bak_e8
to timestamp to_timestamp('2008-11-04 15:00:00','YYYY-MM-DD HH24:MI:SS')
alter session set nls_date_format='YYYY-MM-DD HH24:MI:SS';
ORA-01555: snapshot too old: rollback segment number 21 with name "_SYSSMU21$" too small
报1555错误说明已经不能闪回了,undo空间里面的信息已经被新的undo覆盖了
ORA-08180: no snapshot found based on specified time
4 在回收站里面可以看到删除的表
select * from dba_recyclebin

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境