Resimleri Farklı Kaydet’i Engelleme

Yazdığınız uygulamadaki resimlerin indirilmesini istemiyorsanız browser default özelliği olan sağ tıklamayla resmi kaydet, resmi farklı kaydet gibi seçenekleri engellemeniz gerekir. Bunu jquery sorgusuyla basit bir şekilde yapabilirsiniz.

Buradaki slideImage resmin olduğu divin Id’sidir.

$(document).ready(function () {
$(‘#slideImage’).bind(‘contextmenu’, function () { return false; });
});

Visual Studio 2015 değişken değerlerini debug’ta görememe

Visual Studio 2015 fails to evaluate variables when two versions of assembly are loaded.  Debug yaparken AddWatch , QuickWatch ile değişken değerlerini kontrol ettiğimizde referanslardan birinin iki defa yüklenmiş olmasından dolayı null exception gibi bir uyarı çıkmaktadır. Bunu aşmak için Debug – > Options ->Debugging -> General ‘ın altında Use the legacy C# and VB expression evaluations seçeneği işaretlenmelidir. Bu şekilde değerleri görebilirsiniz.

 

enter image description here

 

Hatalar ve Çözümleri

MVC : Entity ‘de bir değişiklik yapıp kaydetmeye çalıştığımızda ” Validation failed for one or more entities. See ‘EntityValidationErrors’ property for more details ” şeklinde bir hata alıyorsak  en olası sebebi şunlar olabilir  :

  1. Veritabanında (database) NULL olamaz olarak yapılandırılmış (Allow Nulls işareti kaldırılmış) bir alana NULL değer girmeye çalışmak
  2. Belirtilen üst sınır dışında veri giriyi yapmaya çalışmak, örneğin, nvarchar(5) olan bir alana 5 karakterden uzun veri girişi yapmaya çalışmak.

Çözüm olarak try catch bloğunda

catch (DbEntityValidationException e)
{
     foreach (var eve in e.EntityValidationErrors)
     {
           Response.Write(string.Format("Entity türü \"{0}\" şu hatalara sahip \"{1}\" Geçerlilik hataları:", eve.Entry.Entity.GetType().Name, eve.Entry.State));
       foreach (var ve in eve.ValidationErrors)
       {
         Response.Write(string.Format("- Özellik: \"{0}\", Hata: \"{1}\"", ve.PropertyName, ve.ErrorMessage));
        }
         Response.End();
         }



şeklinde bir kod parçasıyla hangi property’den dolayı hata alındığını görebiliriz.

C#  :  System.InvalidCastException: Specific cast is not valid (Belirtilen atama geçerli değil ) hatası : Bu hata iletilecek datanın beklenen şekilde alınmadığı ya da atandığı datatable, list vs. ile uyumlu olmadığından dolayı verilebiliyor. Bu hatayla entity’de sp’den aldığım datayı datatable atarken aldım. Sp’nin döndüğü cursor’u kontrol ettiğimde bir kolonun , den sonraki ondalık kısım da uzun bir rakamlar dizisi geldiğini gördüm. Round ile kolonun 3 haneli gelmesini sağlayınca hata düzeldi.

SQL :String or binary data would be truncated : Bu hata tabloya insert etmek ettiğiniz kayıttan dolayı alınabilir. Insert edilen kolonun length’i ile gelen data genişliği uyuşmamaktadır. Kolon length’i arttırılabilir.

MVC : Httpcontext current does not contain a definition hatası : Sebebi Controlller class’ı da HTTPCOntext isimli bir property’ye sahiptir. Buradaki HTTPContext’in altında Current property’si olmadığı için hata alınır.

HttpContext.Current kısmını System.Web.HttpContext.Current şeklinde değiştirmek gerekir.

c# methodları

Clone() Methodu :

Yeni oluşturduğumuz bğir datatable’a var olan bir datatable yapısını set eder. Klonlandığı datatable’ın sadece kolonları ve kolon tiplerini alır datasını kopyalamaz.

DataTable dtAsus=newDataTable();dtModels= dsPCModels.Tables[0].Clone();

Select() Methodu :

Elimizde var olan bir datatable verileri üzerinde bir kısıtlama işlemi yapıyorsak Select()  metodu ile ihtiyacımız olan datayı seçebiliriz. Metodu parametresiz çağırdığımızda tüm datatable kopyalanacktır.

DataRow[] result = table.Select(“Year >= 30 AND Department = ‘IT'”);

Copy() Methodu:

Var olan bir tablonun yapısını ve datalarını yeni bir datatable‘a kopyalar.

DataTable dt= dtMobiles.Copy();

CopyToDataTable() Methodu:

Datarow diziisini datatable a kopyalar.

DataRow[] drw = dtStudents.Select();

DataTable dt = drw.CopyToDataTable();

Compute(“SUM(),””) Metodu :

Elimizdeki datatable’ın belirli kolonundaki verilerin toplamını object türünde verir.

object toplamOgrenciNot = m_DtTahsilatOran.Compute(“SUM(OgrenciNot)”, “”);
int notlarToplami= Convert.ToInt32(toplamOgrenciNot);

C# ta İki DataTable’ı tek bir data table da birleştirme

DB ile connection Stringleri ya da kullandığımız katmanlı yapılarla DB’den çektiğimiz dataset veya datatable’ları birleştirmek için öncelikle kolon sayılarının eşitliliği ve uyumluluğu gereklidir.

Burada DataTable’lara datayı getirdiğimizi varsayarak devam edeceğim. DtDeveloper ve DtTester diye isimlendirdiğim iki tablo yu atayacağım tablonun ismine DtTeam diyorum.
DataTable dtTeam=new DataTable(“Project Teams”);

eATMBackOffice eATMSmart = new eATMBackOffice();
dsSmartATM = eATMSmart.SubeATMKasaListesi(m_DatabaseLayer, branchCd);

for (int i = 0; i < dtDeveloper.Columns.Count; i++)
{
dtTeam.Columns.Add(dtDeveloper.Columns[i].ColumnName, typeof(string));
}

foreach (DataRow drDeveloper in dtDeveloper.Rows)
{
dtTeam.Rows.Add(drDeveloper .ItemArray);
}
if DtTester != null && DtTester .Tables[0].Rows.Count > 0)
{
DtTester = DtTester .Tables[0];

foreach (DataRow drTester in DtTester .Rows)
{
dtTeam.Rows.Add(drTester.ItemArray);
}
}

Merge ve Copy de kısaca değin