7 Ekim 2013 Pazartesi

Csharp Anahtar Kelimeler (Keywords) Yazı Dizisi - Lock Kullanımı

merhaba,

bu makalede csharp içerisindeki lock deyimini ve bu deyimin ne işe yaradığını incelemeye çalışacağız;


Lock özellikle çok kanallı programlama esnasında kullanılır.Lock içerisindeki işlemler bitmeden diğer işlemler yapılmaz.Thread uygulamalarında lock ile belirtilen işlemler önce yapılır diğerleri sıraya sokulur.Lock içerisindeki işlem bitmeden tekrardan Lock çalıştırılamaz.

private Object Kilit = new Object(); -- Lock Nesnemizi Oluşturalım

lock (Kilit)
{
List.Add("Deger");
}

Şeklinde Kullanılır.

C# Anahtar Kelimeler(Keywords) Yazı Dizisi - Checked ve Unchecked

Merhaba,

bu makalemizde c# dilinde yer alan anahtar kelimelerden(keywords) bazılarını inceleyeceğiz;ne işe yaradıklarını öğrenecek ve her biri için bir adet küçük örnek yapacağız.



Checked ve Unchecked : Bu Operatör tür dönüşümlerini kontrol altında tutmak için kullanılır.Tür dönüşümlerinin yapılabilirliliğini kontrol eder.Yapılamazsa overflow verir ve değişkenlerin eski değerini korur.unchecked; checked içerisinde kontrol etmek istemediklerimiz için kullanılır.

int i=5;
byte c;
checked
{
b=(byte)i;
unchecked
{
c=(byte)a;
}
}


İmplicit ve Explicit : Implicit ve Explicit operator ile bir tipin başka bir tipe çevrilebilirliğini sağlayabiliriz.Base bir class'tan türeyen iki farklı class ı birbirlerine dönüştürmeye yarar.Cannot implicitly convert type x to x hatasinin çözümü bu şekilde sağlanır.

public class Musteri
{
public int DogumYili{ get; set; }
public string Cinsiyet{ get; set; }
}

Şimdi Müşteri class'ımızın bir örneğini yaratalım ve değişkenlerini set edelim;

Musteri _musteri=new Musteri();

Class İçerisindeki DogumYili değerini bir int değişkene atmaya çalışalım.
int Yil=DogumYili;    -->bu satırda  Cannot implicitly convert type Musteri to Int Hatası alırız.


public class Currency
{
public int DogumYili{ get; set; }
public string Cinsiyet{ get; set; }
public static implicit operator decimal(Musteri c)
{
return c.Value;
}
}
yukarıdaki şekilde kullanımda bu sorunu aşabilir ve dönüşüm işlemini gerçekleştirebiliriz.




17 Eylül 2013 Salı

Devexpress - CheckedListBox Kullanımı (DataBound Bağlantılı)

Merhabalar,


bu makalede devexpress'in checkedListbox kullanımına değinecek ve databound şeklinde nasıl kullanacağımızı öğrenmeye çalışacağız.bilindiği üzere checkedlistbox kontrolü sayesinde birden fazla özellik arasından çeşitli seçimler yapabiliyoruz.Özellikle çoklu seçim yapılabilen işlemlerde Microsoft'un standart kontrollerine göre çok daha efektif çalıştığını söyleyebilirim.lafı fazla uzatmadan bu nesnenin üzerinde yaptığımız işlemleri veri tabanına nasıl yansıtırız onu inceleyelim;


Bir form açıp checkedlistbox atalım ve Dock özelliğini 'True' hale getirelim.



Sırada veritabanımızdan ilgili dataları çekip kontrole bağlamamız kaldı.Formumuzun Load Kısmına gelip aşağıdaki kodları yazıyoruz.
SqlConnection con = new SqlConnection(@"Data Source=.\;Initial Catalog=test_db;Integrated Security=True");
con.Open();
SqlCommand command = new SqlCommand("SELECT musteri_adi,Aktif FROM musteri", con);
SqlDataReader reader = null;
reader = command.ExecuteReader();
while (reader.Read()) checkedListBoxControl1.Items.Add(new CheckedListBoxItem(reader["musteri_adi"].ToString(), (bool)reader["Aktif"]));
reader.Close();
con.Close();


Bu kısmın üzerinde çok fazla durmak istemiyorum bu makalede.Data işlemleri ile ilgili diğer makalelerimde geniş bilgi bulabilirsiniz.Load kısmında her Datarow için CheckedListbox kontrolüne yeni bir
item ekliyoruz,Value Özelliğini ve CheckState durumunu veritabanından aldığımız DataRow değerlerine göre ayarlıyoruz.Sonuçta Aşağıdaki Görüntüyü elde etmemiz gerekiyor.

Şimdide Değişiklikleri veritabanımıza yansıtacak olan kod bloğunu yazalım;

checkedListBoxControl'ün ItemCheck event'ına aşağıdaki kod bloğunu yazıyor;

SqlConnection con = new SqlConnection(@"Data Source=.\;Initial Catalog=test_db;Integrated Security=True");
con.Open();
SqlCommand command = new SqlCommand("UPDATE musteri SET Aktif='" + Convert.ToBoolean(e.State) + "' WHERE musteri_adi='" + checkedListBoxControl1.GetItemValue(e.Index) + "'", con);
command.ExecuteNonQuery();
con.Close();
Örnek olması açısından mümkün olduğunca basit tuttum örneği anlaşılır olması açısından.siz daha farklı şekillerde kullanımını sağlayabilirisiniz.



Bir Sonraki Makalemizde Görüşmek Üzere

3 Eylül 2013 Salı

SQL Server Mail Hizmetini Kullanmak

Merhaba;

Bu makalemde sql server üzerinden nasıl mail gönderebileceğimiz konusunda bilgi sahibi olmaya çalışacağız.bilgi sistemleri ortamında haberleşmenin temel yollarından birisi de e-mail dir kuşkusuz.büyük çapta bir proje geliştiriyorsanız kullanıcıları mail ile çeşitli konularda bilgilendirmek isteyebilirsiniz.bu makalenin yazımında bu kriter göz önüne alınmıştır.


SQL Server ortamında mail gönderebilmek için kullanabileceğimiz sp_sendmail Prosedürü bulunmaktadır.Bu prosedür SQL Server ile beraber gelmektedir.Prosedürü kullanabilmek için Database Management içerisinden Database Mail özelliğini aktif etmeniz ve geçerli bir hesap tanımı yapmanız gerekmektedir.Lakin prosedür tarafından gönderilen mailler bu Mail hesabı üzerinden gitmektedir. "Send Test Mail" diyerek hesap ayarlarınızın doğruluğunu kontrol edebilmeniz mümkündür.


Aşağıdaki T-SQL Kod parçası sp_sendmail fonksiyonunun kullanımına Örnektir;


CREATE TRIGGER [dbo].[MailTrigger] 
ON [dbo].[FATURALAR]
AFTER INSERT -- hangi işlemlerde triggerin çalışacağını belirliyoruz, insert, update, delete gibi
AS
DECLARE @SiraNo INT
DECLARE @FaturaNo NVARCHAR(50)
DECLARE @Icerik NVARCHAR(50)
BEGIN

Select @SiraNo = SiraNo From Inserted
Select @FaturaNo = Cari From Inserted
set @Icerik =CAST(@SiraNo AS NVARCHAR) + 'Numaralı Fatura Ödemesi Gerçekleştirildi'

exec msdb.dbo.sp_send_dbmail
@profile_name='MAILPROFILE',
@recipients='ALICI ADRESLERİ','ALICI ADRESİ2','ALICI ADRESİ3'
@subject='EMAİL KONUSU',
@body=@Icerik -- EMAİL İÇERİĞİ
END
GO

Burada Bir Mail trigger'ı tanımlanmış ve FATURALAR tablosuna atanmıştır.Faturalar tablosuna yapılan kayıt(INSERT) sonrasında mail trigger'ı faaliyete geçecek ve "recipients" kısmında belirtilen mail adreslerine Tanımladığınız Mail Hesabı üzerinden mail gönderimi yapacaktır.

Bu Makalenin konusu olmamakla birlikte madem yazdık o zaman hatırlatmasınıda yapalım ;
Select @SiraNo = SiraNo From Inserted
Select @FaturaNo = Cari From Inserted

After INSERT Trigger'ı tanımladığımız için "From Inserted" tanımlaması ile INSERT edilen kaydın ilgili kolonlarındaki bilgileri almış olduk.

Bu Makalede yanlızca Database Mail üzerinden Mail gönderimii incelenmiş ve Database Mail Yapılandırmasını bildiğiniz varsayılmıştır.Database Mail yapılandırması için Aşağıdaki Kaynaklara Göz atabilirsiniz.



Visual C# - .NET Otomatik Class Oluşturma

Merhaba;

Bildiğiniz üzere c# %100 nesne yönelimli bir programlama dili.haliyle herşey bir nesneden ibaret.programlama yaparken nesnesel bir yapı kullandığımızdan dolayı çoğu kez veritabanındaki tablolara karşılık gelen classlar oluşturmamız gerekir.Bir takipçimin isteği üzerine hazırlamış olduğum aşağıdaki t-sql kod bloğu sayesinde parametre olarak verdiğiniz tablo adına ait kolonları sizlere field olarak getirebilmektedir.



CREATE FUNCTION [dbo].[CLASS_Olustur](@TabloAdi AS NVARCHAR(50)) RETURNS @DonusTablo  TABLE(Name NVARCHAR(50))
AS BEGIN
INSERT INTO @DonusTablo(Name)
SELECT * FROM (
SELECT 'Public '+CASE
WHEN TipAd='nvarchar' then 'string'
WHEN TipAd='char' then 'char'
WHEN TipAd='nchar' then 'char'
WHEN TipAd='varchar' then 'string'
WHEN TipAd='sysname' then 'string'
WHEN TipAd='xml' then 'string'
WHEN TipAd='image' then 'string'
WHEN TipAd='date' then 'DateTime'
WHEN TipAd='datetime' then 'DateTime'
WHEN TipAd='smalldatetime' then 'DateTime'
WHEN TipAd='tinyint' then 'bool'
WHEN TipAd='smallint' then 'bool'
WHEN TipAd='real' then 'decimal'
WHEN TipAd='money' then 'decimal'
WHEN TipAd='float' then 'decimal'
WHEN TipAd='bit' then 'bool'
WHEN TipAd='text' then 'string'
WHEN TipAd='int' then 'int'
WHEN TipAd='bigint' then 'UInt64'
WHEN TipAd='decimal' then 'decimal'
END +' '+KolonAd+';' AS Degisken
FROM(SELECT col.name AS KolonAd,tip.name AS TipAd FROM sys.all_columns AS col
INNER JOIN sys.tables AS tp ON
col.object_id=tp.object_id AND tp.name=@TabloAdi
INNER JOIN sys.types AS tip ON
col.user_type_id=tip.user_type_id) AS VW1) AS VW2
RETURN END

GO





Paylaşımlarınızda lütfen kaynak belirtiniz.Emeğe Saygı.....
Kolay Gelsin.


17 Ağustos 2013 Cumartesi

Netsis OS Yükleyici Kilidi Hatası ve Çözümü

netopenx dll'i ile visual studio üzerinde program geliştirmeye çalıştığınızda Aşağıdaki Hatayı Alabilirsiniz;


"OS Yükleyici kilidi içinde yönetilen yürütme girişiminde bulunuluyor. DllMain veya görüntü başlatma işlevi içinde yönetilen kod çalıştırma girişiminde bulunmayın, aksi durumda uygulamanın kilitlenmesine neden olabilir."


Bu Hatanın 2 Çözümü vardır;

  • Uygulamanızı Build Ettikten Sonra bin/Debug klasörü içerisindeki .exe'den Çalıştırabilirsiniz.
  • Visual Studio "Debug" Menüsünden "Exceptions\Managed Debugging Assistans" içerisindeki LoaderLock Property'sinin "Thrown" Özelliğini False Olarak Değiştirebilirsiniz.,


2. Çözüm çok daha mantıklı.çünkü debug yapabilirsiniz.


Kolay Gelsin.

16 Ağustos 2013 Cuma

SQL Server Basit Sql Sorguları

Bu yazımda basit sql sorgulamalarından bahsedeceğim.

Basit SQL sorgulamaları kayıtlar için SELECT, İNSERT, DELETE ve UPDATE komutlarından oluşur. Adlarındanda anlaşılacağı gibi;
select: Kayıtları seçmeye yarar
insert: yeni bir kayıt eklemeye yarar
delete: veritabanından herhangi bir kayıt silmeye yarar
update: Tabloda bulunan bir kayıt’ı güncelleme veya değiştirme amacı ile kullanılır.



Bunun yanında birde veritabanı nesneleri için kullanılan ALTER, DROP, CREATE komutlarıda mevcuttur. Bu komutlar çok fazla kullanılmamak ile birlikte bilmemiz gereken komutlardır. Çoğumuz veritabanı üzerinde işlem yaparken arayüzü kullanarak database table gibi nesneler oluşturur veya düzenleriz. Tabi ki arka planda bu komutların çalıştığını bilmeli, yeri geldiğindede komut ile bu işlemleri yapabileceğimiz uygulamalar yazabilmeliyiz.

alter: RDBMS’de bulunan herhangi bir nesneyi DÜZENLEMEK için kullanılır.
drop: RDBMS’de bulunan herhangi bir nesneyi SİLMEK için kullanılır.
create: RDBMS’de bulunan herhangi bir nesneyi OLUŞTURMAK için kullanılır.

Yazımda öncelikle alter,drop ve create komutlarınlarının kullanımını basit şekilde anlatıp select insert delete ve update komutlarına geçeceğim.

CREATE Komutu

Yukarıdada bahsettiğim gibi bir nesne oluşturmak için kullanılır. Biraz daha açıklayıcı olalım,
Bir veritabanı oluşturmak istiyorum. Adı ise deneme olsun.

create database deneme

Bir tablo oluşturmak istiyorum. adı uyeler olsun. tablonun alanları isim telefon ve aciklama olsun. Birde benzsersiz kimlik bilgisi için id kolonum olucak.

use deneme - diyerek hangi database’yi kullanacağımı belirtiyorum.
create table uyeler (

id int unsigned not null auto_increment primary key,
isim varchar(45),
telefon varchar(20),
aciklama text
);

DROP Komutu

Drop komutu bir nesneyi silmek için kullanılır.
bir veritabanını silmek istiyorum.

drop database deneme

bir table silmek istiyorsam ise

drop table uyeler



ALTER Komutu

Alter kullanımı T-SQL konusu olduğu için burada bahsedip kafa karıştırmayacağım. Bununla ilgili bilgiye aşağıdaki linkden yada birgün yazacağım T-SQL kategorisindeki ilgili makalemden ulaşabilirsiniz.

http://msdn.microsoft.com/tr-tr/library/ms174269(v=sql.100).aspx – İlgili MSDN sayfası





SELECT, İNSERT , UPDATE VE DELETE KOMUTLARI

SELECT Komutu

Select komutu bir tablomuzdan kayıt çekmemizi sağlar.Veritabanı sorgulamaları yaparken öncelikle ne işlem yapacağımızı berlitmemiz gerekir. Örneğin okuma işlemi yapacaksak;

select diye başlamalayız. Sonrasında tablomuzda hangi field’ları yani hangi sütunları istediğimizi söylemeliyiz.

id,isim,telefon gibi field’larımızı belirttikden sonra ise hangi tablomuzdan bu verileri çağıracağımızı belirtmeliyiz. bunun için from deyimi kullanılır. FROM deyimi, herhangi bi işlemi hangi tablo üzerinde gerçekleştireceğimizi belirtmemize yarar. Standart kalıp…

from uyeler diyerek uyeler tablomuzdan veri çekiceğimizi söyledik. Son olarak sorgumuzun geldiği durum;

select id,isim,telefon from uyeler Bakın bu kadar basit işte…

Not: Eğer tablonun her sütununu çekmek istersek * sembölünü kullanabiliriz. Bu sembol aynı zamanda SQL’de “Hepsi” anlamına gelmektedir.

Örneğin;
select * from uyeler



INSERT Komutu

İnsert komutu ise bir tabloya veri eklemek amacı ile kullanılmaktadır. Bu komutun çok çeşitli kullanımları vardır, tabi bu kullanımların sonucu aynı olsada yerine göre hangisi kolayımıza gidiyorsa onu kullanırız.

Basit bir insert işleminde, select’de ve her sorguda olduğu gibi önce insert işlemi yapacağımızı bildiriyoruz.

insert bu noktada artık veritabanı bizim insert yapacağımızı biliyor. Şimdi hangi tabloya yapacağımızı söyleyeceğiz. bunun için into komutu kullanılır.

into uyeler artık RDBMS bizim uyeler tablosuna bir kayıt ekleyeceğimizi biliyor. Şimdi hangi field’ların bu işden etkileneceğini, yani hangi field’ların verilerini göndericeğimizi söyleyeceğiz.

(isim,telefon) diyerek isim ve telefon field’larına veri göndereceğimi açıklamış oldum. Şimdi ise yapmam gereken hangi veriler? değerlerimizi bildireceğiz. Bunun için values deyimi kullanılarak veriler gönderilir.

values(“Can”,”0123456789″) Buradada verilerimizi bildirmiş olduk. Dikkat edilmesi gereken bir husus; Tamsayı veri tipli alanlarımız için tırnak işareti kullanılmamalıdır. String tipli veriler için ise tırnak işareti kullanılmalıdır. Burada id sütunumun değerini göndermedim, auto_increment özelliği atadığım için otomatik artacaktır. Bu özelliğe detaylı olarak daha sonra değineceğiz…

son olarak sorgumuzun yapısı şu şekilde olucaktır;

insert into uyeler(isim,telefon) values(“Can”,”0123456789″)

Başka bir kullanım;

insert into uyeler values (”,”Can”,”0123456789″,”Bu bir açıklama yazısıdır”)
Bu şekil kullanımda ise her field’ ın değerini vermek zorundayız…

UPDATE Komutu

Bu komut tabloda bir veri yada bir grup veriyi düzenlemek amacı ile kullanılır. Her zaman ki gibi önce veritabanına bir güncelleme işlemi yapacağımızı update ile bildiriyor, sonrasında hangi tablomuz için kullanıcağımızı söylüyoruz.

update uyeler buradan sonra yapmamız gereken değişecek field’lar ve yerine yazılacak değerleri göstermemiz gerekiyor. bu işlemi yapmak içinde set kelimesi ile bildiride bulunuyoruz.

set isim=’Can’, telefon=’0123456789′ gibi. Sorgumuzun son durumu ise;

update uyeler set isim=’Can’, telefon=’0123456789′
şeklinde olucaktır.

Unutmayın! update ve delete işlemlerinde where kelimesi kullanılmaz ise tablonun tüm kayıtları etkilenecektir. Çünkü veritabanı sizin bu güncelleme veya düzenleme işlemini hangi kayıt üzerinde yapacağını bilemez. Ayrıca; where komutununda etkileyeceği kayıtları göz önünde bulundurarak sql kodunuzu yazınız. Örneğin tek bir kayıt etkilenecek ise mutlaka benzersiz bir sütun adı tanımlayın.

DELETE Komutu

Diğer komutlar gibi delete komutunda da öncelikle veritabanına silme işlemi yapacağımızı söylemeliyiz. Örneğin;

delete Sonrasında hangi tablo üzerinde kayıt siliceğimizi söylemeliyiz.

delete from uyeler Burdada uyeler tablosundan kayıt sil demek istedik.

Fakat bu şekilde tüm kayıtları sileceği için where deyimi ile tanımlayacağımız kriterlere sahip verileri sil diyebiliriz. Örneğin;

delete from uyelere where id=1
Şeklinde… Yada;

delete from uyelere where isim=’Can’
Gibi….





Bu Yazımızda basit sql komutlarını anlamış olduk. Biraz uygulama, deneme yanılma yöntemleri ile öğrendiklerimizi uygulamamız gerekiyor ki, daha sonra unutmayalım :)

Bir sonraki dersimde where deyimini anlatacağım. Görüşmek üzere…