Ana içeriğe atla

Kayıtlar

2013 tarihine ait yayınlar gösteriliyor

ORACLE12C YENİ ÖZELLİK: Clone Pluggable Database

Oracle 12c ile gelen bu yeni özlelik ile uygulamanıza yapılacak bir deployment öncesi pre-prod yapmak istenildiğinde veya performans problemleri incelerken veritabanının bir kopyasına ihtiyaç duyduğumuzda bu yöntemle veritabanımızın bir kopyasını oluşturabiliriz. Bu örnekte Container Database(CDB)'deki bir pluggable database(PDB)'den clone alınarak yine aynı CDB'de başka bir PDB veritabanı oluşturduk. Çalışmaya başlamadan önce yeterli disk alanı olduğunu kontrol edilmeli. DB isimleri: CDB: test12c PDB: pdb1 Oluşturulacak PDB: pdb2 -- Clone alınacak database'in read-only modda olması gerekiyor. İlk önce pdb'lerin durumlarına bakarız. SQL> select name,open_mode from v$pdbs; NAME                           OPEN_MODE ------------------------------ ---------- PDB$SEED                       READ ONLY PDB1                           READ WRITE -- Clone alınacak database'in read-only modda açılır. SQL> alter pluggable database PDB1 close immedi

Oracle 11G - Interval Partitioning Özelliği

Bilindiği üzere devasa tablolara erişimde performans sıkıntılarının giderilmesi, data arşivleme, büyük hacimlerdeki eski dataların silinmesi gibi durumlarda partitioning hayat kurtarıyordu. Bununla birlikte 11g öncesi versiyonlarda bu tabloların sürekli yeni partition'larının oluşturulması gibi bir maliyet söz konusuydu. Önceki versiyonlarda partition yaparken belirtilen zaman aralığı dışında bir veri girmeye çalıştığımız zaman "ORA-14400: inserted partition key does not map to any partition" hatasını alıyorduk, çünkü girmek istediğiniz verinin konumlandırılacağı bir partition bulunmamaktaydı. 11g ile partition create ederken "interval" ifadesini de ekleyerek tablomuza belirtilen aralıkların dışında bir data gelmesi durumunda ilgili partition'ı kendisi oluşturuyor. 11g ile gelen bu yeni özellik sayesinde artık partitioning seçeneğine daha bir ısındım diyebilirim.  Aşağıda bir örnekle açıklamaya çalıştım. Bu örnekte eski dataları, farklı bir arşiv tables

Veritabanı dosyalarını(datafile) başka bir dizine taşıma

Bu işlem veritabanı kapalıyken veya açıkken yapılabilir. 1 ) Veritabanı Kapalıyken: * Database kapatılır. SQL > shutdown imeediate * Datafile yeni dizine kopyalanır veya move edilir. $ cp /old_location/dbfilename01.dbf /new_location/ Taşımayıp kopyaladıysanız eski lokasyondaki datafile'ı kullanmasını önlemek adına ek önlem için rename edebiliriz. $ mv /old_location/dbfilename01.dbf /old_location/dbfilename01.dbf_OLD * Database mount mode'da açılarak datafile rename edilir. SQL > startup mount SQL > alter database rename file '/old_location/dbfilename01.dbf' to '/new_location/dbfilename01.dbf'; * Database open mode'a alınır. SQL > alter database open; 2 ) Veritabanı Açıkken: Bunu yapabilmek için database'in archive log mode'da olması gerekiyor. Bunu aşağıdaki komutla kontrol edebilirsiniz. SQL> select log_mode from sys.v_$database; LOG_MODE ------------ ARCHIVELOG * Datafile offline'a alınır. SQL> al