16 Nisan 2010 Cuma

Bir Tablodan Rastgele 5 Kayıt Getirmek

-- Önce test etmek için geçici bir tablo tanımlayalım.  
DECLARE @Dummy TABLE(ID int identity(1,1),Number int)

-- Bu tabloya 100 tane kayıt atalım.

-- SQL Server 2008 de değişkeni tanımlarken başlangıç değeri de verebilirsiniz. SQL Server 2008 öncesinde tanımlamayı ve başlangıç değeri vermeyi ayrı satırlarda yapmalısınız.
DECLARE @i int = 1
WHILE @i<=100 BEGIN
  INSERT INTO @Dummy(Number) VALUES(@i*@i)
  SELECT @i+=1 -- Bu da SQL Server 2008 e ait bir özellik. SELECT @i=@i+1 ifadesine karşılık gelir.
END

-- Dataları çekeceğimiz tablomuzu oluşturduk. Bakalım nasıl kayıtlar var.
SELECT * FROM @Dummy


    ID    Number
    1    1
    2    4
    3    9
    4    16
    5    25
    6    36
    ..    ..
    99    9801
    100    10000


Şimdi bu tablodan rastgele 5 tanesini seçelim. 

SELECT TOP 5  *
FROM @Dummy
ORDER BY NewID()

ID    Number
99    9801
25    625
65    4225
51    2601
15    225


NewID fonksiyonu  uniqueidentifier tipinde bir veri oluşturur ve her çektiğinizde de farklı bir değer oluşturur. Her seferinde farklı değerler üreten bu fonksiyonu ORDER BY a ekledim, böylece bizim tablomuzun kayıt yaratılma sırasına göre değil, anlık üretilen NewID ye göre sıralayacak kayıtları. "TOP 5" ifadesi de ilk 5 kaydın gelmesini sağlayacak.

DECLARE @Guid uniqueidentifier = NewID()
SELECT @Guid as Guid

Guid
7facc454-b048-4e44-8d72-b7a9b97fb370




Akla hemen neden random sayı üreten RAND() fonksiyonunu kullanmadık diye bir soru da gelebilir.
RAND() fonksiyonu  bir transaction içinde aynı sayıyı üretir.

SELECT RAND() as Random, * FROM @Dummy

kodunu çalıştırırsak Random kolonunda hep aynı sayının geldiğini görebilirsiniz.

Hiç yorum yok: