• Anasayfa
  • Hakkımızda
  • Etkinlikler
  • Destek Verin
  • Site Haritası
  • Giriş Yap
  • Üye Ol
  • Facebook
  • Twitter
  • RSS
Yazılım Dilleri
  • Soru - Cevap
  • EĞİTİM SETİ
  • KATEGORİ
  • DUYURU
  • TEKNOLOJİ HABERLERİ

Son Sorular

  • 23.04.2016 00:55:33C programlama 2 oyun
  • 20.04.2016 16:34:41Local Database
  • 15.04.2016 14:26:15Fatura kayıt işlemi
  • 21.03.2016 01:55:30C# problem

Popüler Sorular

  • 27.05.2012 05:49:50Asp.Net ile Date time alana veri ekleyemiiyorum ?
  • 2.04.2012 00:45:18.exe uzantılı dosya için dijital imza nerde nasıl alınır.
  • 12.05.2012 08:44:49Acil Yardım
  • 27.05.2012 13:46:51veri tabanı bağlantısı
  • .Net Framework
  • 8085 Assembly
  • Active Directory
  • ADO.NET
  • Android
  • Apple IOS
  • Arduino
  • ASP.NET
  • ASP.NET MVC
  • Blackberry
  • C#.Net
  • C++
  • CCG Framework
  • CISCO
  • CSS
  • Diğer
  • Dreamweaver
  • Entity Framework
  • Exchange Server
  • Gömülü Sistemler
  • GSM Programlama
  • Güncel
  • Güvenlik
  • HTML5
  • Java
  • Javascript / JQuery
  • Jira
  • Kariyer ve İş Yaşamı
  • LINQ
  • LibreOffice
  • Linux
  • Matlab
  • Microsoft Dynamics CRM
  • Mobil Uygulama Geliştirme
  • MySQL
  • NoSQL
  • Oracle
  • OWIN
  • PFSense
  • PHP
  • Powershell
  • Python
  • Sanallastirma
  • SAP-ABAP
  • SCOM 2012
  • SEO
  • Sharepoint 2010
  • Sharepoint 2013
  • Silverlight
  • Sistem Analiz ve Tasarımı
  • SQL Server
  • Symantec
  • TFS
  • T-SQL
  • Ubuntu
  • VB.NET
  • Veritabanı Yönetim Sistemleri
  • Visual Studio
  • VMware
  • WCF
  • Web Hosting
  • Windows 8
  • Windows Azure
  • Windows Phone 7.1
  • Windows Phone 8
  • Windows Server
  • Wordpress
  • WPF
  • Xamarin
  • XNA
  • Yazılım Mühendisliği
  • Yöneylem Araştırması
  • ASP.NET MVC
  • Entity Framework
  • Javascript / JQuery
  • LINQ
  • PHP

Son Duyurular

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

Oracle 11g ile Gelen Editioning Özelliği

Uygulama gelişticilerin çok esneklik sağlayan versiyonlama özelliği ORACLE 11gR2 ile geldi. Oracleda bu özellik editioning olarak adlandırılmaktadır. Bu makalede edition özelliğinin oracleda nasıl çalıştığı anlatılacaktır.

10.03.2013

Yazar: Ahmet Sedef (Google+)

Kategori: Oracle

3007

Oracle 11g ile birlikte edition özelliği gelmiştir. Edition özelliği sayesinde bir herhangi şema altındaki bir nesnenin farklı versiyonları üzerinde çalışabiliriz. Bu makalede edition özelliğini nasıl kullanacağımızı basit örnekler üzerinde anlatılacaktır. Yapacağımız işlemlere başlamadan önce database in mevcut hangi edition da olduğunu kontrol edelim. Bunun için sqlplus'tan sysdba ile bağlanıyoruz. Kontrolun tam olması için

SQLPLUS / AS SYSDBA

Oracle 11g release 2 ile birlikte her database defaul olarak bir edition düzeyindedir. Bu editionın adı ORA$BASE dir. Databasein default olarak hangi edition düzeyinde olduğunu öğrenmek için aşağıdaki şu sql cümleciğini çalıştırılmalıdır;

SELECT property_value
  FROM database_properties
 WHERE property_name = 'DEFAULT_EDITION';

sorgu sonucunda ORA$BASE görürürüz. Şimdi database için editionları oluşturalım. Editionları oluşturmadan önce database kullanıcısının CREATE ANY EDITION ve DROP ANY EDITION haklarına sahip olmalıdır. Bu haklara sahip olan bir database kullanıcısı, edition oluşturma, edition silme haklarına sahip olacaktır. Örnek yetki verme işlemi için sytax şu şekildedir (db_user burada temsili kullanıcıdır. SYSDBA olarak log in olduğum için yetkilendirme işlemi yapmama gerek yoktur).

CREATE ANY EDITION db_user;
DROP ANY EDITION db_user;

Editionları oluşturmak için sytaxlar;

CREATE EDITION r_v1;
CREATE EDITION r_v2 AS CHILD OF r_v1;


Yukarıda iki farklı edition oluşturuldu. Birinci edition r_v1 ve bu edition altında olan ve editionın child editionu olan r_v2. r_v2 edition, CHILD olmasının gerekliliğinden dolayı r_v1 deki edition edilen objeleri katılsal olarak kendine alır. Editionları silmek için

DROP EDITION r_v1;

Databasedeki edition düzeylerini global olarak database seviyesinde yapacağımız gibi, session bazlı olarak da edition düzeyleri değiştirilebilir. Databasede global edition değişiminde bütün şemalardaki nesneler ilgili edition düzeyindeki hallerine dönerler. Bunun için

ALTER DATABASE DEFAULT EDITION = r_v1;

User (Şema) bazında edition değişliği için

ALTER USER edition_test ENABLE EDITIONS;

Session bazında edition değişikliği için

ALTER SESSION SET EDITION = r_v1;

Ayrıca user için GRANT USE ON EDITION hakkı verilmelidir.

GRANT USE ON EDITION r_v1 TO db_user;
GRANT USE ON EDITION r_v2 TO db_user;

Çalıştığımız database kullanıcının hangi edition düzeyinde olduğunu sorgulamak için SYS_CONTEXT den yararlanabilinir. Bunun aşağıdaki sorgu çalıştırılmalıdır.

SELECT SYS_CONTEXT('USERENV', 'SESSION_EDITION_NAME') AS EDITION FROM DUAL;

Çalışılan edtion düzeyinde nesnelere yapılacak değişiklikler, değişikliğin yapıldığı düzeyde ve child düzeylerde etkili olur. Edition edilecek nesneler şunlardır;
 

  • FUNCTION
  • LIBRARY
  • PACKAGE and PACKAGE BODY
  • PROCEDURE
  • TRIGGER
  • TYPE and TYPE BODY
  • SYNONYM
  • VIEW



EDITIONING VIEW: Tek bir tablodan olan selectler için oluşturulur. Datanın geldiği tablo üzerinde DDL işlemlerinden izole olmak için kullanılır. Databasede DBA_EDITIONING_VIEW, ALL_EDITIONING_VIEW ve USER_EDITIONING_VIEW viewleri edition viewlerin hakkında bilgi edinmek için kulanılır. Örnek sytax şu şekildedir;

CREATE OR REPLACE EDITIONING VIEW view_name
(col1,
col2,
col3 as col3_name)
AS
SELECT col1, col2, col3
from table_name

EDITIONING FUNCTION ve PROCEDURE: Farklı edition düzeylerinde var olan fonksiyonlarda değişiklik yapılmadır. Yapılan değişiklik ilgili edition düzeyinde geçerli olacaktır. Aynı durum procedure için de geçerlidir.



 

Yazar Hakkında

Ahmet Sedef

Ahmet Sedef

ahmetsedef.wordpress.com

2010 yılında Yıldız Teknik Üniversitesi İstatistik Bölümünden mezun oldum.İş zekası alanında kariyerime devam ediyorum. İlgi Alanımlarım; Oracle, MS SQL Server, PL/SQL,T-SQL, Java, Informatica, Oracle Data Integrator,IBM Datastage

Sosyal Medya

ORANLAR

  • 3007izleme

Arkadaşlarınla Paylaş

  • Tweet

0 Yorum

Yorum Yaz / Soru Sor

Lütfen yorum yazmak veya soru sormak için üye girişi yapınız.

Son Yorumlar

  • Böyle bir sayfalama ağ trafiğini hafifleti...
  • Merhaba, ellerinize sağlık çok yardımcı ol...
  • Merhaba Bu uygulama örneğinden ASP.net ...
  • Hocam Link başka sayfaya yönlendiriyor.
  • merhaba benim merak ettiğim bir konu var y...

En Güncel Sorular

  • Bilgilendirme maili (C#.Net)
  • Power Pivot (Sharepoint 2010)
  • BigInteger, BigDecimal (Asp.Net ve Asp.Net MVC)
  • visual C# ile asp nette veritabanı islemleri (Asp.Net ve Asp.Net MVC)
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ? (Sharepoint 2010)

En Son Cevap Verilen Sorular

  • Bilgilendirme maili
  • BigInteger, BigDecimal
  • visual C# ile asp nette veritabanı islemleri
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ?
  • txt dosyasına veri yazma

Twitter

Takip et: @yazilim_dilleri

En Çok Okunanlar

Elif BAYRAKDAR

C# ile SQL Server Bağlantısı, Insert, Update ve Delete Sorguları

23.05.2013

  • 122030
  • 0
Hakan Keskin

C# ile Windows Service Projesi Oluşturma, Debug Etme ve Setup Hazırlama

17.12.2013

  • 68134
  • 0
batuhan avlayan

Php - Mail Gönderme (İletişim Formu)

02.09.2013

  • 49928
  • 0

Sponsorlar

KODLAB
Pluralsight
Exchange server is
Office 365
YAZILIM DİLLERİ
Yukarı Çık
  • Hakkımızda
  • Facebook
  • Twitter
  • RSS

© Yazılım Dillerinin Buluşma Noktası | Kaynak belirtildiği sürece makaleler kopyalanabilir.
YazilimDilleri.Net sitesinde yer alan kullanıcıların oluşturduğu tüm içeriklerin yayınlanması ile ilgili yasal yükümlülükler içeriği oluşturan kullanıcıya aittir, YazilimDilleri.Net hiçbir şekilde sorumlu değildir.

Kapat

Giriş Yap

Kullanıcı Adı

Şifre

Şifremi Unuttum

KULLANICI GİRİŞİ