27 Nisan 2010 Salı

Rastgele Sayı , Kayıt ve Tarih Üretmek

Aşağıdaki kod örneklerinden yararlanarak rastgele sayı, rastgele tarih ve rastgele kayıt üretebilirsiniz.


Kod biraz karmaşık görünebilir ancak mantığı çok basit.
Rastgele sıralama yapmak için kullandığımız NewID() fonksiyonu yine yardımımıza koşuyor.
1. NewID() den integer tipinde bir sayı üretmek için  tip çevirme işlemi yapıyoruz.
2. Sayıların negatif gelme olasılığı da var. Bu nedenle abs fonksiyonuna alıyoruz ki her zaman pozitif bir sayımız olsun.
3. Ancak tarih aralığının en büyük tarihi geçmesini istemediğimiz için öncelikle en büyük - en küçük tarih arasındaki gün sayısına göre, ürettiğimiz sayının modunu alıyoruz.
4. Sonra da yaptığımız şey, en küçük olmasını istediğimiz tarihe bu sayıyı eklemek.  Tarihlerdeki toplama işlemi ilgili tarihe gün sayısı ekliyor.

Sonuç, çok hızlı çalışan ve verdiğimiz tarih aralığı arasında rastgele bir tarih üreten bir fonksiyon.

SalesCount'u hesapladığımız yerde de sadece rastgele sayıyı üretiyoruz ve @mod değişkeninde   verdiğimiz sayı kadar bir sayı üretmesine izin veriyoruz.


-- buraya 20 tane kayıt ekliyorum. İçinde ne olduğu önemli değil. Önemli olan rastgele data üretmemi sağlayacak kayıt olması
DECLARE @Cnt table(Number int)
DECLARE @i int = 1
WHILE @i<=20 BEGIN
  INSERT INTO @Cnt(Number) VALUES(@i)
  SET @i+=1
END

-- A,B ve C ürünlerim olsun.
DECLARE @Product TABLE(ProductName varchar(10))
INSERT INTO @Product(ProductName) VALUES
('A'),('B'),('C')

-- Rastgele üreteceğim tarihin aralıklarını belirtiyorum.
DECLARE @mindate DATETIME = '2010-01-01'
DECLARE @maxdate DATETIME = '2010-05-31'

DECLARE @mod int = 50

SELECT
  (@mindate +(ABS(CAST(CAST( NewID() AS BINARY(8) )AS INT)    ) % CAST((@maxdate - @mindate) AS INT    )    )    ) SalesDate, -- rastgele bir tarih üretelim
  ABS(CAST(CAST( NewID() AS BINARY(8) )AS INT)    ) % @mod as SalesCount, -- rastgele bir sayı üretelim. Mod'u 50 verdim ki en fazla 49 üretsin ve büyük rakamlarla uğraşmayayım.
  P.ProductName
FROM @Cnt C CROSS JOIN @Product P

Hiç yorum yok: