MsSql ile .Net’ de sayfalama (paging) yapmak
Ben, sizlere sayfalama yapmak için 2 farklı mssql kodu yazacağım ama bu kodları anlatmadan önce, mysqlde bu iş nasıl yapılıyor ona bakmak gerek. Çünkü benim yazacağım bir mssql kodu mysqldekine benzer yapıda olacaktır.
Mysql’de sayfalama yapmak için LIMIT kelimesini kullanmak yeterlidir.
Örnek mysql komutu yazarsak ;
SELECT * FROM uye LIMIT 0,10
yukardaki kodu çalıştırdığımızda bize ilk 10 sıradaki kaydı getirecektir. ve limit değerlerini değiştirerek mesela 10,20 yapsak bize 10 la 20 arasındaki verileri getirecektir.
Mssql de ise mysqldeki gibi limit gibi komutu olmadığı için bu işi biraz farklı yoldan yapmamız gerekecek.
1. MsSQL Komutu :
SELECT * FROM (SELECT ROW_NUMBER() OVER (ORDER BY id ASC) AS Row, uye.* FROM uye) AS Row_Tablo WHERE Row_Tablo.Row BETWEEN 10 AND 20
2. Sql cümleciğine göre anlaşılması ve kullanımı son derece daha kolay diyebilirim. Yukarıdaki sql cümlesinde “ROW_NUMBER()” adlı sql fonksiyonu sayesinde satır numaralarını sırası ile yazdırıyoruz. Aşağıdaki resimde “Row” ve “id” adlı sütunlarına bakarsanız ne demek istediğimi anlarsınız

Satır numarasını aldıktan sonra işimiz daha da kolay artık. Bundan sonra mysql deki LIMIT kavramının bir benzerini yapıp paging olayını kolaylık yapabileceğiz. “WHERE Row_Tablo.Row BETWEEN 10 AND 20″ WHERE cümleciği ile “Row” sütununda yazan 10 ile 20 arasındaki değerleri alacağız. Eğer biz ilk 10 değeri almak isteseydik “WHERE Row_Tablo.Row BETWEEN 0 AND 10″ yazacaktık.
Bu kadar basit.Şimdi sıra diğer bir yönteme geldi. Bu sql cümleceği daha uzun ve ilk yönteme göre daha komplike haldedir.
2. MsSQL Komutu :
SELECT TOP 20 * FROM uye WHERE (id NOT IN ( SELECT TOP 10 id FROM uye ))
Yukarıdaki kodu açıklamak istersek eğer, “SELECT TOP 20 * FROM uye” sql komutunda bize ilk 20 kaydı getirecektir. Sql komutunun devamına bakıcak olursak eğer, ” SELECT TOP 10 id FROM uye ))” burada ise ilk 10 kaydın sadece id numaralarını getiriyoruz ve bu iki sql komutunu ” ( id NOT IN (” ile bağlıyoruz. Yani sql cümlesi bize ilk 20 kaydı getir ancak ilk 10 kayıt hariç. Bu sql cümlesi bizim için 2. sayfadaki kayıtları dönderecektir. Biz ilk sayfadaki verleri isteseydik eğer, ilk sql deki TOP 20 yerine TOP 10, ikinci sql cümlesindeki TOP 10 yerine TOP 0 ‘ ı yazacaktık.
Benim fikrimi soracak olursanız tabikide ilk yöntem daha iyi olacaktır haliyle ama 2. yöntemi kullanmak isteyenlerde onu kullanabilir. Zaten bizim için sonuç aynı olacaktır
Eğer başka fikri veya yöntemi olan varsa bu sayfadan paylaşabilir
Birçoğumuzun (elbette ben de varım) ufkunuda genişletmiş olur hem
Örnek veritabanını indirmek için tıklayın.
Yorum Yapın
Etiketler
Son Yazılar
- Cep telefonu kullanıcılarını mobil siteye nasıl yönlendirilir?
- require vs require_once
- IFrame ‘in yüksekliğini içeriğe göre ayarlamak
- Bmp uzantılı resim dosyasını jpg veya png olarak kaydetmek
- Php Resim Boyutlandırmasında Memory Limit sorunu
Son Yorumlar
- Php’ de Ajax yardımıyla dosya yükleme (File Upload) için chat
- Asp.Net’de Ajax kullanılarak CAPTCHA için Enes Pekkaya
- Asp.Net’de Ajax kullanılarak CAPTCHA için Cenk
- JQuery Form Kontrol için Sedat Kumcu
- Garanti Sanal Pos Kurulumu, Sorunlar ve Çözümler için Enes Pekkaya
Haftanın Özlü Sözü
Bağlantılar
- Hayata Tat Kat
- Innova Bilişim Çözümleri
- Onur Değerli
- Pleksus Bilişim Teknolojileri
- Sinan Gül
- Taner Günal
- Toppik – Minoxil
Arşivler
- Mart 2012
- Şubat 2012
- Ocak 2012
- Aralık 2011
- Kasım 2011
- Ekim 2011
- Eylül 2011
- Temmuz 2011
- Haziran 2011
- Mayıs 2011
- Mart 2011
- Ocak 2011
- Aralık 2010
- Kasım 2010
- Ekim 2010
- Eylül 2010
- Ağustos 2010
- Temmuz 2010
- Haziran 2010
- Mayıs 2010
- Nisan 2010
- Mart 2010
- Şubat 2010
- Ocak 2010
- Haziran 2009
- Mayıs 2009
- Nisan 2009
- Mart 2009

