13 Aralık 2013 Cuma

Global Temporary Tables GTT

ORACLE'in geçici kayıt tutmak için sunduğu bir tablo yapısı var. Bu tablo bir kez yaratılıyor. Bundan sonra ister kodun içinden ister TOAD gibi aracın içinden ORACLE'a bağlanın, bu tabloya yazdığınız kayıtları sadece siz görüyorsunuz. Kod bloğunuzda veya TOAD'ın içinden COMMIT veya ROLLBACK yaptığınızda tablo yazdığınız kayıtların ömrü bitmiş oluyor. ORACLE'ın  bizim yerimize bu tabloya sessionID diye bir sütun açtığını ve bu tabloya gelen okuma yazma sorgularının başına bu kuralan bağlantının (session'ın) Id^sini yazdığımızı düşünebiliriz.

Ne gibi problemlerin üzerinden gelmek için bu yaklaşımı kullanabiliriz?  (Bu amaçla yarattığımız tablonun adının PARAMETER_TABLE_GTT olduğunu düşünelim)

Rapor sorgusunu yazarken, raporu çalıştırdığımız parametleri Rapor sorgurunu içine  = :KUMPANYA_ID veya IN :KUMPANYA_ID_LIST diye ekleriz.  Rapor çalıştığında bizim parametrelerimiz, sorgu betiği içinde bunlarla yer değiştirir ve orjinalinde sanki bizim gönderidğimiz değerler varmış gibi çalışır. View içine parametre geçmek diye tabir edebileceğimiz bu yaklaşımı,  istediğimiz parametleri PARAMETER_TABLE_GTT kayıt ederek ve orijinal sorgumuzu bu tabloya join yaparak gerçekleştirebiliriz.

Kod içinden elde ettiğimiz ve başka bir sorgunun WHERE kısmına  IN ile eklemek istediğimiz değerleri bu tabloya yazarak, orijinal sorgumuzda bu tabloya exist olarak ekleyebiliriz.

Ayrıntılı bilgiye buradan ulaşabilirsiniz.


Örnek bir kullanımın adımları

Tablo Yaratılması  (Bir kez yapılacak bir işlemdir)

DROP TABLE YNA.PARAMETER_TABLE_GTT CASCADE CONSTRAINTS;

CREATE GLOBAL TEMPORARY TABLE YNA.PARAMETER_TABLE_GTT
(
  NUMBER_ALAN1  NUMBER
)
ON COMMIT DELETE ROWS
RESULT_CACHE (MODE DEFAULT)
NOCACHE;

GRANT DELETE, INSERT, SELECT, UPDATE ON YNA.PARAMETER_TABLE_GTT TO ORACLEREADERUSER;


View içinde kullanımı
DH_DA_GOP_SEF_KUMP_DA_VW tablosunda LEFT JOIN veirilmiş bir alt sorgunun içinde kullanılıyor. Bu alt sorgunun (aslında diğer tablolar ile bağlantısını bir alan üzerinden kuramadığımız) sadece istediğimiz parametre için çalışmasını istiyoruz.
..
..
(
..
  FATURA , DH_DA_SEFER_KUMPANYA ,
                             PARAMETER_TABLE_GTT GTT
                       WHERE    
                              DH_DA_SEFER_KUMPANYA.KUMPANYA_ID = GTT.NUMBER_ALAN1


Kod içerisinden çağırımı

            TransactionHelper txnHelper = new TransactionHelper();
            txnHelper.BeginTransaction();
            try
            {
                //txnHelper yaşamı boyunca geçici kayıt (ParameterTableGttEntity) tablosuna bir kayıt atıyor.
                //DhDaGopSefKumpDaVwCollection içinde bu tabloya JOIN atılıyor. View içine parametre geçmek için yazıldı.
                var prmTableGttEntity = new ParameterTableGttEntity();
                txnHelper.AddElementToTransaction(prmTableGttEntity);
                prmTableGttEntity.NumberAlan1 = request.KumpanyaId;
                prmTableGttEntity.Save();
                TypedListBuilder tlb = new TypedListBuilder();
                tlb.addFields(DhDaGopSefKumpDaVwFields.DaGopSeferLokasyonId, DhDaGopSefKumpDaVwFields.DaGopSeferLokasyonId.Name);
                tlb.addFields(DhDaGopSefKumpDaVwFields.DaKumpanyaId, DhDaGopSefKumpDaVwFields.DaKumpanyaId.Name);
                tlb.addFields(DhDaGopSefKumpDaVwFields.DaNo, DhDaGopSefKumpDaVwFields.DaNo.Name);
                
                //Veri çektiğimiz yapıda aynı Transaction'i kullanmalıyız.
                response.DhDaSeferKumpanyaDT = tlb.Fill(filtre, sortExpression, TxnHelper);
                //Tabloya attığımız kayıt bu noktada silindi.
                txnHelper.CommitTransaction();
            }
            catch (Exception)
            {

15 Kasım 2013 Cuma

ORA-02293 NOT NULL CHECK CONSTRAINT

Belli bir tarihten sonrası NOT NULL, belli bir tarihten öncesi NULL olarak yaşamına devam edecek kolonlar için ALTER TABLE MUSTERI ADD CHECK ("ULKE_LOKASYON_ID" IS NOT NULL); şeklindeki notasyon ihtiyaca cevap vermiyor. Bu notasyon kolonun tamamını NOT NULL'a çeker. Column description ekranında NULL? Bölümünde N gösterir. (eğer başarılı çalışırsa)
 
Bizim ihtiyacımıza cevap veren notasyon ALTER TABLE MUSTERI ADD (  CHECK ("ULKE_LOKASYON_ID" IS NOT NULL)  ENABLE NOVALIDATE); Bu durumda column description ekranındaki NULL? Bölümü Y gösterse de hayatına NOT NULL olarak devam eder, eski kayıtları NOT NULL'a zorlamaz.

24 Eylül 2013 Salı

asp.net mvc bundle 403 hatası

Merhaba,
Asp.Net MVC uygulamalarımızda bundle kullandığımız zaman, bundle ismi fiziksel bir path ile aynı olursa css veya js isteklerine 403 forbidden cevabı dönüyor.
Bunun sebebi ilk olarak IIS handler’ların çalışması ve fiziksel dizine isteğin yönlendirilmesi.
Çözüm basit;
bundle ismini değiştirin (önerilen) veya aşağıdaki alıntıda yer alan B maddesini uygulayın. İstekleri .Net karşılasın.
This issue is by default .NET does not "process" requests that have a .js or .css extension.
There are two fixes for this (you only need to do ONE)
A) Remove the extensions from the bundle names. (recommended) This will cause .NET to process the request and run it through the BundleModule.
B) Add this to your web.config in the 
system.webServer section which will cause .NET to run .js and .css requests through the BundleModule.
<modules runAllManagedModulesForAllRequests=
"true">
 <remove name="BundleModule" />
 <add name="BundleModule" type="System.Web.Optimization.BundleModule" />
</
modules>
Big shout out to Ray Moro who figured out the actual cause and shared it with me on my blog:http://blog.cdeutsch.com/2012/11/fixing-404-errors-for-aspnet-mvc-apps.html
 

18 Eylül 2013 Çarşamba

Asp.Net 4.5 Kurulumu Ardından Ajax Isteklerinde Yaşanan Bir Hata

Merhaba,

 

Web sunucularimiza .Net Framework 4.5 kurduktan sonra ilginc bir problem yasamaya basladik.

Bazi IE9 ve alti kullanan userlarin browserlarinda kitlenmeler olustu. Ayni senaryoyu farkli bowserlar ile denedikleri zaman sıkıntı yasamadilar (chrome, IE10 gibi).

Konuyu arastırdigimizda sorunumuza en uygun asagidaki linke ulastık.

 

http://stackoverflow.com/questions/15437524/managedpipelinehandler-for-an-ajax-post-crashes-if-an-ie9-user-navigates-away-fr

 

Yine bu linkte yer alan asagidaki cozumu uyguladik ve hata tekrar yasanmadi.

<system.webServer>
<serverRuntime uploadReadAheadSize="0" />
</system.webServer>


How to set the uploadReadAheadSize in IIS 7.5

  1. Launch "Internet Information Services (IIS) Manager"
  2. Expand the Server field
  3. Expand Sites
  4. Select the site you want to make the modification for.
  5. In the Features section, double click "Configuration Editor"
  6. Under "Section" select: system.webServer>serverRuntime
  7. Modify the "uploadReadAheadSize" section
  8. Click Apply

 

4.5 icin bu tip sorunlari cozen bir fix/patch var mi diye arastirdigimizda;

 

Download yapilamayan bir hotfix rollup;

http://support.microsoft.com/kb/2828841/en-us

 

Bir update paketi;

http://www.microsoft.com/en-us/download/details.aspx?id=36359

 

ve asagidaki bilgilerle (4.5.1 preview);

 

ile karsilastik.

Isterseniz fix’i kurabilir, isterseniz uploadReadAheadSize değerini değiştirip devam edebilirsiniz.

 

Serkan

16 Ağustos 2013 Cuma

WCF Servislerinde Unity Kullanımı

WCF servislerinizde Unity veya farklı bir Dependency Injection Framework’u kullanmak istiyorsanız aşağıdaki makale oldukça yardımcı.
Kendimize özel ServiceHostFactory oluşturup register işlemlerini istediğimiz gibi yapabiliyoruz.
 
 
Dikkat edilmesi gereken önemli bir not:
** WcfHostClient.exe üzerinden host işlemi yapıyorsanız (development ortamında) kendinize özel ServiceHostFactory’i kullanamıyorsunuz. Bunu aşmak için WebHost isimli bir proje yaratın ve svc dosyanızı yaratın.
Svc dosyada aşağıdaki gibi Factory tanımı yapın. Bu projeyi hem development ortamında, hem de devreye alımlarda kullanabilirsiniz.
 
<%@ ServiceHost Service="Service.Wcf.Service1" Factory="Service.Wcf.MyServiceHostFactory"%>
 
Serkan

13 Mart 2013 Çarşamba

Init Metodunda ViewState Kullanımı

Merhaba

 

Asp.Net uygulamalarında, Controllerin Init metotlarında atama yapılan ViewState değerleri saklanmaz.

ViewState değişimleri InitCompleted işleminde izlenir duruma gelmektedir.

Eğer Init metodunda ViewState ataması yapmak zorundayım derseniz, öncelikle TrackViewState() metodunu çalıştırmanız gerekir.

Dikkat etmeniz gereken bir nokta; Init metodu içerisinde ViewState içerisinde saklanan değerleri okuyamazsınız.

 

Serkan

7 Mart 2013 Perşembe

debug=true'lardan kurtulmanın kökten çözümü

Machine.config dosyasında aşağıdaki gibi belirtirseniz,
deploylarda web.config debug=true mu gitti diye düşünmek zorunda kalmazsınız:

<configuration>
    <system.web>
          <deployment retail=”true”/>
    </system.web>
</configuration>

debug=true dersek ne olur?

1) Sayfaların derlemesi daha uzun sürer
2) Kodlar daha yavaş çalışır
3) Uygulama daha fazla bellek kullanır
4) WebResources.axd'den download edilen script ve resimler önbelleğe alınmazlar ve her istekte tekrar download edilir.

14 Şubat 2013 Perşembe

Visual Studio 2010 Test Projesi Test List Kısmında Değişiklikler Görünmüyorsa

 
Visual studio 2010 Tools/Options’ı açalım.
 
Test Tools/Test Project e tıklayalım, sağ tarafta yer alan “disable background discovery of test methods” kısmındaki check’i kaldırın, sorun düzelsin.