Merhaba, Hoşgeldin!

VSRO.org, Silkroad Online, Knight Online, Metin2 ve diğer çevrimiçi oyunlar için öncü bir yardım ve geliştirme platformudur. Misyonumuz, bilgi ve deneyim sahibi bireyleri, bilgiye ihtiyaç duyanlarla bir araya getirerek, zengin bir etkileşim ortamı yaratmak ve farklı bakış açılarını birleştirmektir. Topluluğumuzda güçlü bir işbirliği ve öğrenme kültürü oluşturarak, herkesin değerli katkılarda bulunmasını sağlıyoruz.

vSRO Çözüldü vSRO Starter Pack Oluşturma (Belirlenen İtemleri Verdirme)

Sieger

vSRO Developer, PK2 Editor
.
.
Katılım
6 Şub 2019
Mesajlar
2,441
Çözümler
6
Tepkime puanı
6,431
Puanları
303
Web sitesi
vsroeditor.com
Türk Lirası
0.00₺
Merhabalar,
Sistem bildiğimiz gift box mantığı ile çalışıyor, bir tablodan verileri çekip oyuncuya exec ile aktarıyor fakat şöyle bir sorunum var.
Farklı bir prosedür ile tek exec kullanarak tabloda ki tüm itemleri oyuncuya verdirebiliyorum.
Devil vermek istediğim an sorun burada başlıyor.
Bildiğiniz gibi male,female olmak üzere 2 devil var benim yapmak istediğim belirlenen ObjCharID Male ise Male Devil, Female ise Female devil vermesi.
Bunu tabloya eklemiyorum, ikinci bir exec ile verdirmeye çalışıyorum fakat hiç bi şekilde olmuyor.

Eğer tabloya eklersek nasıl yapabiliriz?
Ya da tabloya eklemez ikinci exec ile yaparsak nasıl yapabiliriz?

Bunun detaylı anlatımı ya da tam prosedürü hiç bir forum da yok.

Çözüm:

Tablodan item verdirmek yerine aşağıda yazmış olduğum şekilde sorun çözülmüştür.

Sorunu şu şekilde çözdüm, tablodan item vermiyor lakin bir tık daha ileri yürüttüm daha güzel ve temiz oldu.

Please, Giriş yap or Kayıt ol to view spoiler content!

Please, Giriş yap or Kayıt ol to view spoiler content!
2. prosedürü çoğaltmak ve birden çok starter pack eklemek isterseniz 2. prosedür yerine altta ki prosedürü kullanabilirsiniz.

Please, Giriş yap or Kayıt ol to view spoiler content!
 
Son düzenleme:
Please, Giriş yap or Kayıt ol to view quote content!

Sorun fazla exec değil transaction mantıgından ötürü kaynaklanan bir problem. Önceki mesajımda açıklamıştım tekrar izah edeyim. Oyunda scroll kullanıldığı zaman sql bütün _AddLogitem prosedürünü tetikler içerisindeki tüm döngü, koşul vs check eder. Basit gibi görünebilir ancak oyun içerisinde item'ler üzerinde yapılan her türlü işlemde bu prosedür tetiklenir, bunu sql profiler açarak görebiliriz. Örneğin 800 oyunculu bir server'da saniyede yüzlerce kez bu prosedür tetiklenir, bu yüzden bu prosedürün içeriği oldukça önemli diyebiliriz. Transaction'lardaki herhangi bir takılma veya gecikme bir sonraki transaction için sorun teşkil eder. Bu yüzden daha önce belirttiğim gibi olabilecek maximum performansa bu prosedürde ihtiyaç vardır. Gelen her komut için ortalama 2~5 ms execution plan süresi en iyi performansı sağlar. Bu süreler aşıldığı zaman yaşadığın problemlere benzer problemler oluşur.

Performans için sql 2017+ memory OLTP özelliği kullanılarak normal prosedürlerden 30 kat daha fazla performans sağlanabilir ancak bunun için biraz detaylı sql bilmek gerekir. Bu özelliği araştırıp öğrenmekte fayda var.

Bu bilgiler doğrultusunda problemini çözdüğünü ve ileride karşılaşabileceğin bu tarz problemler konusunda biraz aydınlandığını düşünüyorum :)
 
Oyla 0
Please, Giriş yap or Kayıt ol to view quote content!
Bilgilerin ve yardımın için teşekkür ederim, paylaştığım çözüm sonucunda ilk 3-5 kullanımda sorun oluşmuyor lakin sonrasında ki kullanımda 1 itemi vermiyor ve tekrar giftbox kullandığım da çar teleportta takılıp kalıyor, gameserver'ı tekrar başlatmadan da tekrar çara giriş yapılamıyor. Sorun bir nevi devam ediyor diyebilirim.
 
Oyla 0
Oyla 0
@Senua Prosedürler ve sonuçlar aşağı da yazdığım gibi.


Please, Giriş yap or Kayıt ol to view spoiler content!

Please, Giriş yap or Kayıt ol to view spoiler content!

Please, Giriş yap or Kayıt ol to view spoiler content!

Please, Giriş yap or Kayıt ol to view spoiler content!

Ek 1: Kod bloğunu 3-4 defa üst üste execute ettiğim de AddLogItem prosedüründe "SQL Server parse and compile time:" bazen 0 ms. olarak gösteriliyor.
Ek 2: Kod bloğunu 3-4 defa üst üste execute ettiğim de 1. prosedürde "SQL Server parse and compile time:" bazen 0-1 ms. olarak gösteriliyor.
Ek 3: Kod bloğunu 3-4 defa üst üste execute ettiğim de 1. prosedürde "SQL Server Execution Times:" bazen 0-1 ms. olarak gösteriliyor.
 
Oyla 0
Geri
Üst Alt