Oracle Flashback -2

Merhaba Arkadaşlar,

Bu yazımda sizlere Oracle Flashback teknolojisini anlatmaya devam ediyor olacağım. Bir önceki yazının devamı olduğu için önce onu okumanızı tavsiye ederim.

 

Flashback çeşitleri

Flashback teknolojini kullanmak için 2 farklı yöntemimiz bulunmaktadır. Bunlardan biri scn ye göre diğeri tarihe göre dönebilmektir.

SCN ( System Change Number ): Oracle Veritabanı açısından en kritik şeylerden birisi olup bir nevi veritabanımızın saat bilgisidir. Oracle veritabanın da her bir transaction Commitlendiği zaman Oracle Veritabanı SCN yi bir artırıp ilgili transactiona o SCN numarasını verir ve sistemin artık yeni SCN si son commit görmüş transactionın SCN sidir.

Db deki güncel scn değerini bulmak için aşağıdaki komutu çalıştırıyoruz.

 

Select current_scn from v$database;

 

Bu scn nin hangi tarihe geldiğini görmek için aşağıdaki komutu çalıştırıyoruz.

 

Select scn_to_timestamp(481572) from dual;

 

İstediğimiz tarihin hangi scn ye denk geldiğini görmek için aşağıdaki komutu çalıştırıyoruz.

 

Select timestamp_to_scn(to_timestamp('01-03-15 04.26.36','dd.mm.yy hh24:mi:ss'))

 

Scn her veritabanında kendine özgüdür. Çok eski scn lere ulaşamayız. Çünkü bir süre sonra kaybolur.

 

Flashback Database

Flashback database ile Oracle Veritabanımızı eğer Retention yeterliyse istediğimiz kadar geriye götürebiliriz. Tabi bu işlem tüm Veritabanı seviyesinde olduğu için kritik bir operasyondur 3 kere düşünmeden karar vermeyin lütfen.

Bu özelliği genelde Deployment gibi yüklü bir işlem sonrası eğer işlem başarısızsa tüm DB yi geriye almak gerektiğinde kullanmaktayız.

Şimdi iyi pekiştirmeniz açısından bir örnekle göstereyim, deveci diye bir kullanıcı ve onun oluşturduğu deneme tablosu kaybolsun. Flashback sayesinde bunları geri getirebildiğimizi aşağıda göreceğiz.

Öncelikle bu kullanıcı ve tablomun olduğu zamanda alınan bir scn olsun.

Select current_scn from v$database;

382240

Daha sonra kullanıcıyı ve tabloyu drop ediyoruz. Bu işlemin yanlışlıkla olduğunu da düşünebilirsiniz.

Drop user deveci;

DROP TABLE deneme CASCADE CONSTRAINTS ;

 

Daha sonra database imizi flashback ile eski bir SCN ye döndürmek için aşağıdaki adımları uyguluyoruz.

 

Shutdown immediate;

Startup mount;

Flashback database to scn 382240;

Alter database open resetlogs;


Bu operasyon sonunda kaybolan veriler geri geldiğini görebiliriz.

Eğer time olarak geri almak istiyorsak aşağıdaki komutu çalıştırmamız gereklidir.

 

Flashback database to timestamp to_timestamp('29-07-16 04.26.36','dd-mm-yy hh24.mi.ss');

 

  • Eğer elimizde eski bir backup var ise database flashback yaptıktan sonra drop edilen datafile’ı rman sayesinde advise failure ile geri getirebiliriz.
  • Aksi taktirde datafile ler geri getirilemez. Sadece üzerinde yapılan değişiklikler getirilir.
  • Undo datafile üzerinde shrink yapılırsa flashback kullanamayız.
  • Control file backuptan restore yapılır ise flashback ile en fazla control file ın restore yapıldığı yere kadar dönebiliriz.
  • Database imizi read only modda açmamızın avantajı şudur. Eğer flashback yapacağımız tarihi bilmiyorsa read only modda açıp gerekli verilerin gelip gelmediğiniz kontrol edebiliriz.
  • Eğer veritabanı read only modda ise ve flashback yaılmamış haline geri dönmek istiyorsak recover database dememiz gerekir.

 

Flashback Table

Flashback table özelliğini de adı üstünde Tablo bazında geri götürme amaçlı kullanabiliriz. Bu özelliği bir DBA olarak çok kullanmaktayım, çoğu kez developer lar yada business taraftaki IT çalışanları bazı tabloları yanlışlıkla drop edebiliyorlar bu durumda eğer flashback açıksa flashback table ile bu tabloyu geri getirebiliyoruz. Bu özelliği kullanabilmemiz için row movement özelliğini enable yapmamız gerekir. Enable etmek için aşağıdaki komutu çalıştırıyoruz.

 

Alter table deneme row movement;

 

Test etmek için önce bir tablo oluşturup daha sonra delete etmeye ve flashback ile geri dönmeye çalışalım.

 

Create table deneme as Select * from dba_tables;

 

Sorgu çektiğimizde gelen sonuç aşağıdaki gibidir.

Select count(*) from deneme;

562

Daha sonra mevcut scn mize bakıyoruz.

 

Select current_scn from v$database;

384344

 

Şimdi tablomuza delete çalıştırıp flashback ile geri getirelim.

Delete * from deneme;

Commit;

 

Daha sonra tablomuzda kaç kayıt kaldığına bakalım.

 

Select count(*) from deneme;

0

 

Şimdi flashback ile scn mize geri dönelim.

 

flashback table deneme to scn 384344;

 

Şimdi tablomuzda bulunan kayıtlara tekrar bakalım.

 

Select count(*) from deneme;

562

 

Her tablo için flashback kullanamayız. Örneğin data dictionary table, system table, remote table gibi tablolara flashback kullanamayız.

 

Eğer istersek Bazı tablespaceleri bu özellikten çıkarabiliriz. Bunun için aşağıdaki komut aşağıdaki gibidir.

 

Alter tablespace deveci flashback off;

 

 Flashback Query

Bu teknoloji sayesinde sorgularımızı belirttiğimiz zamandaki datalara göre sorgu çekebiliriz.

Buradaki senaryomuzda önce bir tablo yaratıp. Daha sonra scn alıp veriler ekleyip, commit yaptıktan sonra flashback query özelliğimizi deneyelim.

 

Create table deneme(id number,name Varchar2(20));

 

Scn mizi öğrenelim.

 

Select current_scn from v$database;

409505

 

Tablomuza veri ekleyip commit yapalım.

 

Insert into deneme values(1,'Deveci');

Commit;

 

Tabloya güncel sorgu attığımızda gelen değer

 

Select count(*) from deneme;

1

 

Flashback query ile sorgu attığımızda gelen değer

 

Select count(*) from flasdeneme AS OF SCN 409505;

0

 

Her scn için bu şekilde sorgu atamayız. Buradaki kısıtlayıcı etmen undo table space inin alanı ile ilgilidir. İlgili retention parametresini aşağıdaki komut ile öğrenebiliriz.

 

show parameter undo_retention;

 

Gelen değer saniye cinsindendir. Bu zaman içerisinde istediğimiz zamana sorguyu atabiliriz.

 

Böylece bu yazınında sonuna gelmiş bulunmaktayım bir sonraki yazıda buluşmak dileğiyle esen kalın..

 

Oracle Exadata SQL Server Goldengate Weblogic EBS ve Linux konusunda aşağıdaki konularda 7×24 Uzman Danışmanlara yada Eğitimlere mi İhtiyacınız var mehmet.deveci@gridgroup.com.tr adresine mail atarak Bizimle iletişime geçebilirsiniz.

– Oracle Veritabanı Danışmanlığı
– Oracle Veritabanı Bakım ve Destek
– Exadata Danışmanlığı
– Exadata Bakım ve Destek
– SQL Server Veritabanı Danışmanlığı
– SQL Server Veritabanı Bakım ve Destek
– Goldengate Danışmanlığı
– Goldengate Bakım ve Destek
– Linux Danışmanlığı
– Linux Bakım ve Destek
– Oracle EBS Danışmanlığı
– Oracle EBS Bakım ve Destek
– Weblogic Danışmanlığı
– Weblogic Bakım ve Destek
– Oracle Veritabanı Eğitimleri
– Oracle VM Server Danışmanlığı
– Oracle VM Server Bakım ve Destek
– Oracle EPPM Danışmanlığı
– Oracle EPPM Bakım ve Destek
– Oracle Primavera Danışmanlığı
– Oracle Primavera Bakım ve Destek
– Oracle Eğitimleri
– SQL Server Eğitimleri
– Goldengate Eğitimleri
– Exadata Eğitimleri
– Linux Eğitimleri
– Oracle EBS Eğitimleri
– Oracle VM Server Eğitimleri
– Weblogic Eğitimleri
– Oracle EPPM Eğitimleri
– Oracle Primavera Eğitimleri

Mehmet Salih Deveci

I am Founder of IT Tutorial and Certified Expert about Oracle & SQL Server database, Goldengate, Exadata Machine, Oracle Database Appliance administrator with 10+years experience.I have OCA, OCP, OCE RAC Expert Certificates I have worked 100+ Banking, Insurance, Finance, Telco and etc. clients as a Consultant, Insource or Outsource.I have done 200+ Operations in this clients such as Exadata Installation & PoC & Migration & Upgrade, Oracle & SQL Server Database Upgrade, Oracle RAC Installation, SQL Server AlwaysOn Installation, Database Migration, Disaster Recovery, Backup Restore, Performance Tuning, Periodic Healthchecks.I have done 2000+ Table replication with Goldengate or SQL Server Replication tool for DWH Databases in many clients.If you need Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS Consultancy and Training you can send my email adress mehmetsalih.deveci@outlook.com.-                                                                                                                                                                                                                                                 -Oracle DBA, SQL Server DBA, APPS DBA,  Exadata, Goldengate, EBS ve linux Danışmanlık ve Eğitim için  mehmetsalih.deveci@outlook.com a mail atabilirsiniz.

Leave a Reply

Your email address will not be published. Required fields are marked *