Maison base de données tutoriel mysql ORACLE常用的查询语句

ORACLE常用的查询语句

Jun 07, 2016 pm 03:19 PM
oracle 查询 死锁 pratique 解锁 语句

==========================死锁查询及解锁======================= 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的


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

 

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
4 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Combien de temps les journaux de la base de données Oracle seront-ils conservés ? Combien de temps les journaux de la base de données Oracle seront-ils conservés ? May 10, 2024 am 03:27 AM

La durée de conservation des journaux de la base de données Oracle dépend du type de journal et de la configuration, notamment : Redo logs : déterminé par la taille maximale configurée avec le paramètre "LOG_ARCHIVE_DEST". Redo logs archivés : Déterminé par la taille maximale configurée par le paramètre "DB_RECOVERY_FILE_DEST_SIZE". Redo logs en ligne : non archivés, perdus au redémarrage de la base de données et la durée de conservation est cohérente avec la durée d'exécution de l'instance. Journal d'audit : Configuré par le paramètre "AUDIT_TRAIL", conservé 30 jours par défaut.

Fonction pour calculer le nombre de jours entre deux dates dans Oracle Fonction pour calculer le nombre de jours entre deux dates dans Oracle May 08, 2024 pm 07:45 PM

La fonction dans Oracle pour calculer le nombre de jours entre deux dates est DATEDIFF(). L'utilisation spécifique est la suivante : Spécifiez l'unité d'intervalle de temps : intervalle (tel que jour, mois, année) Spécifiez deux valeurs de date : date1 et date2DATEDIFF(interval, date1, date2) Renvoie la différence en jours

L'ordre des étapes de démarrage de la base de données Oracle est L'ordre des étapes de démarrage de la base de données Oracle est May 10, 2024 am 01:48 AM

La séquence de démarrage de la base de données Oracle est la suivante : 1. Vérifiez les conditions préalables ; 2. Démarrez l'écouteur ; 3. Démarrez l'instance de base de données ; 4. Attendez que la base de données s'ouvre ; 6. Vérifiez l'état de la base de données ; . Activez le service (si nécessaire) ; 8. Testez la connexion.

Comment utiliser l'intervalle dans Oracle Comment utiliser l'intervalle dans Oracle May 08, 2024 pm 07:54 PM

Le type de données INTERVAL dans Oracle est utilisé pour représenter les intervalles de temps. La syntaxe est INTERVAL <precision> <unit> Vous pouvez utiliser des opérations d'addition, de soustraction, de multiplication et de division pour utiliser INTERVAL, ce qui convient aux scénarios tels que le stockage de données temporelles et. calculer les différences de dates.

De quelle quantité de mémoire Oracle a-t-il besoin ? De quelle quantité de mémoire Oracle a-t-il besoin ? May 10, 2024 am 04:12 AM

La quantité de mémoire requise par Oracle dépend de la taille de la base de données, du niveau d'activité et du niveau de performances requis : pour le stockage des tampons de données, des tampons d'index, l'exécution d'instructions SQL et la gestion du cache du dictionnaire de données. Le montant exact dépend de la taille de la base de données, du niveau d'activité et du niveau de performances requis. Les meilleures pratiques incluent la définition de la taille SGA appropriée, le dimensionnement des composants SGA, l'utilisation d'AMM et la surveillance de l'utilisation de la mémoire.

Comment voir le nombre d'occurrences d'un certain caractère dans Oracle Comment voir le nombre d'occurrences d'un certain caractère dans Oracle May 09, 2024 pm 09:33 PM

Pour trouver le nombre d'occurrences d'un caractère dans Oracle, effectuez les étapes suivantes : Obtenez la longueur totale d'une chaîne ; Obtenez la longueur de la sous-chaîne dans laquelle un caractère apparaît. Comptez le nombre d'occurrences d'un caractère en soustrayant la longueur de la sous-chaîne ; de la longueur totale.

Exigences de configuration matérielle du serveur de base de données Oracle Exigences de configuration matérielle du serveur de base de données Oracle May 10, 2024 am 04:00 AM

Exigences de configuration matérielle du serveur de base de données Oracle : Processeur : multicœur, avec une fréquence principale d'au moins 2,5 GHz Pour les grandes bases de données, 32 cœurs ou plus sont recommandés. Mémoire : au moins 8 Go pour les petites bases de données, 16 à 64 Go pour les tailles moyennes, jusqu'à 512 Go ou plus pour les grandes bases de données ou les charges de travail lourdes. Stockage : disques SSD ou NVMe, matrices RAID pour la redondance et les performances. Réseau : réseau haut débit (10GbE ou supérieur), carte réseau dédiée, réseau à faible latence. Autres : alimentation stable, composants redondants, système d'exploitation et logiciels compatibles, dissipation thermique et système de refroidissement.

Les tâches planifiées Oracle exécutent l'étape de création une fois par jour Les tâches planifiées Oracle exécutent l'étape de création une fois par jour May 10, 2024 am 03:03 AM

Pour créer une tâche planifiée dans Oracle qui s'exécute une fois par jour, vous devez effectuer les trois étapes suivantes : Créer une tâche. Ajoutez un sous-travail au travail et définissez son expression de planification sur "INTERVAL 1 DAY". Activez le travail.

See all articles