(15/12/2020, 00:32)atoykan yazdı: Merhaba Sayın @schecter
Sorunlarınıza kısaca cevap vermeye çalışayım.
1. Access veritabanını paylaşıma açmaktan kastınız veritabanını bölmeden paylaşmak ise asla tavsiye etmeyeceğimiz bir uygulamadır. %99 olarak yaşayacağınız sorun kayıt çakışmasıdır ki kilitlenme ve çökmelere sebep olur. Sürekli onarma ve kurtarma ile uğraşırsınız ve bazen kurtaramayabilirsiniz. Bunun yerine veritabanını bölerek paylaşıma açmalısınız. Bölme ile ilgili başlıklarımızı incelerseniz yaşayabileceğiniz tüm sorunlar ve gerekli tedbirler ile ilgili fikriniz olacaktır.
2. Kullanıcı arayüzü olarak Access kullanmak eldeki kaynağı kullanıp tasarruf etmek anlamında değerlendirilebilir ancak şahsi görüşüm Sql serverda bir veritabanı düşünülüyor ise Access neden derim. Sql serverın çok daha kompleks ve ölçeklenebilirlik özelliğini Access'de asla bulamayacağınız tartışılmaz. Sorunuz özelinde bakılacak olursa ölçek olarak daha geniş imkana sahip olmanızı sağlayacak olan Sql serverda arayüz olarak Access kullanmak yukarıdaki sorunlarınıza kısmi çözüm getirse de %100 engelleyemez.
3. Bu 1. maddede bahsettiğiniz paylaştırma işleminin en doğru yöntemi olan bölme işlemidir ki bu konu ile ilgili başlıklarımızı incelemeniz ile ilgil belirttiklerimi tekrarlamıyorum. Ben önemli bir iki kalemi belirteyim:
* Karşılaşabileceğiniz en ciddi sorun kayıt çakışmasıdır. İyi yapılandırılmamış bir bölme işlemi kayıt çakışması, kilitlenme, işlemlerde ciddi süreler ve çökme sorunlarına sebep olabilir. Benim bu hususta tavsiyem tüm veri girişinin akabinde kayda alma ve numaralandırma/kimliklendirmedir ki bu kayıt çakışması sorununu yaşama olasılığınızı en alt seviyeye çekecektir.
* Access'in mevcut yapısı nedeni ile diğer veritabanları ve özellikle sqlserver hızlarına asla ulaşamayacağını unutmayın.
* Veritabanınıza erişecek kullanıcı sayısı diğer veritabanları ile kıyaslandığında daha sınırlıdır. 200 kullanıcya kadar ağır yük işleri yapılmadığı sürece desteklediği Microsoft tarafından belirtilsede belirli sayıda sorgu ve işlemin üzerinde çıkılan veritabanlarında 20-25 kullanıcıdan sonra ciddi performans sorunlarının yaşandığını dönem içinde deneyimledik.
4. Bu çözüm çok daha efektif bir çözümdür. Access'in yapısal esnekliğindeki eksikliği bertaraf ve Sql server performans artılarından faydalanmanın en pratik ve stabil yöntemidir. C# dediğinizde WinForm, WPF, ASP.NET WebFormları, ASP.NET gibi kozlarınız Access'de yoktur mesela bu bile tek başına cevaptır sanıyorum.
Vakit darlığı nedeni ile çok daha detaylı yazamıyorum ancak bu genel başlıklardan yola çıkarak çok daha detaylı da inceleyebilirsiniz.
Umarım işinize yarar. İyi çalışmalar.
Sayın atoykan, cevabınız çok yararlı oldu.
Açıklamanızla ilgili bir konuda teyit almak isterim.
ikinci soruya istinaden açıklamanızda aşağıdaki ifadeyi kullandınız
ölçek olarak daha geniş imkana sahip olmanızı sağlayacak olan Sql serverda arayüz olarak Access kullanmak yukarıdaki sorunlarınıza kısmi çözüm getirse de %100 engelleyemez.
SQL Server ı back end olarak kullandığımda Access front end kullanmassam, Kullanıcı arayüzünü ne ile yapacağız? 4. Sorunuzda cevabını verdiğiniz teknolojiler mi? Eğer o ise programlama bilgim yeterli olmadığından accesse yönelmek durumundayım sanırım.