22 Temmuz 2015 Çarşamba

Yazılım projelerinde Proje Yönetiminin önemi nedir?

Kariyerimin başlangıçlarında oldukça şanslıydım. Egebank'ta Alternatif Dağıtım Kanallarında ve Başarı Telekom/Ticaret'te proje yönetim ofisi benzeri bir birimde çalışırken gerçekten vizyoner, şu sıralar bilinen deyimle mentor sayılabilecek yöneticilerle çalıştım. Son teknolojilere yakın, bir o kadar da bu teknolojileri işlerine adapte etmekte becerikli ekipler kurmuşlardı, gerçekten şimdinin standardına göre mükemmel işler çıkartıyorlardı.
Bu süreçte çalıştığım şirketler benim için eğitici, öğretici olmasının yanında gerçekten tecrübe ve vizyon kazanmama yardımcı olan tek çalıştığım şirketlerdi. Ama bu süreçte edindiğim en önemli tecrübelerimden birini de şuydu.
Türkiye'de dikkat edilmesi gereken ilk şey, insanlar ve teknoloji hazır olmadan bir işe girişmemekti.  Buna pek çok örnek verebilirim. Yine eski geçmişten, Başarı Ticaret döneminden bahsedebilirim.
İlk ürün satışı yapılan e-commerce sitelerinden birini kullanıma açmıştık ve dünya teknolojisini en yakından takip etmek zorunda olan bankaların V-POS altyapısı bile yetersizdi. Her ne kadar Türkiye, teknoloji ve bilinç olarak hazır olmasa da Türk insanı çeşitli yollarla kendini adapte etmişti ve  dolandırılıyorduk. Çalıntı kredi kartları bir tarafa, sahte isimle alışveriş yapıp, ev taşıyanlar bile oluyordu. Değinmeden edemeyeceğim; Bu süreçte ben umutsuzdum, sitenin kapatılması gerektiğine inanıyordum ve yöneticim de hem fikirdi, çünkü kaybettiğimiz ürünler cep telefonlarıydı ve ciddi kaybımız oluyordu. Şirketin sahibi ki kendisi idolümdür, Ferda Yıldız beyefendi ile yöneticim görüşmüştü. Ferda Bey ise şunu söylemişti.
"Burada önemli olan kaybettiğimiz ürünler değil, edindiğimiz tecrübe. Devam edeceğiz ve bir gün dolandırılmamayı öğreneceğiz."
Site yıllarca açık kaldı.
Konumuza geri döneyim.
Daha acı bir erken teknoloji örneği ise sevdiğim bir arkadaşımın VOIP teknolojisini firmalara sunmak için açtığı şirketin batmasıdır. Evet yurtdışında VOIP kullanılıyordu ama Türkiye'de hatlar yetersiz, internet yavaştı. Teknolojiyi dünya ile aynı zamanda kucaklamak, Türkiye'de kabustur.
Teknoloji kadar konseptlerin gelişmesi ve kabul görmesi de Türkiye'de yaklaşık bir 7 sene geriden gelmektedir. Yurtdışında aksaklıklar tespit edildiğinde, geliştirilen ve denenen pek çok yöntem ve uygulama Türkiye'ye ulaştığında çoktan değerini yitirir ama yine de uygulanır. Sonuç yurtdışındaki ile aynıdır, onların terk ettiği başka bir uygulamaya gidilir.  Ama dünya siz daha başlarken o uygulamadan daha da iyisine yönelmiş olur.
Proje Yönetimi de aslında bu geç kalınmış uygulamalardan biridir. Geçerliliği kabul görmüş, standartları oturmuş, sertifikasyonları önem kazanmıştır. Dünya değerini şuanda Türkiye'dekinden kat be kat fazla görmektedir ve iş alanı olarak tamamen farklılaşmış, oturmuştur. Bu da seneler sonra Türkiye'de değerini anlayacak demektir. Biz anlayıp oturtana kadar yurtdışında daha etkili bir sistem kabul görmezse tabii.
Uzun seneler yazılımcı olarak çalıştım ama yazılımcı demek o zamanlar analist/testçi/proje yöneticisi/müşteri ilişkileri uzmanı gibi titleları da barındırıyordu. Tek kişilik orkestra gibiydiniz. Pek çoğunuzun hem fikir olacağı gibi işin içindeyken aksaklıkları ve nedenleri daha iyi görebilirsiniz. Yöneticileriniz veya patronlar sizi dinleseler pek çok şey daha iyi işleyebilir. Benim farkım ise bu aksaklıkları gidermek için ne yapılabilir diye düşünmekti ve dünyayı takip etmekti.
Yazılımcılık dönemindeki bir yöneticim, yazılım projelerinin gereğinden fazla uzun sürmesinden şikayetçi idi ve kendine göre bir çözüm de bulmuştu. Framework geliştirmek. Bu çözümü uygulamaya sokmak çeşitli çabalara rağmen 5 sene aldı ve beklenen tabii ki olmadı, zaten bu işi başlatan yönetici de çoktan şirketten ayrılmıştı. Aslında sorun hiçbir zaman framework yazmak veya hızlı kodlama yapmak değildi. Sorun yönetimseldi.
1.  

 
Projelerde bildiğiniz gibi kapsam/zaman/bütçe birbiriyle en ilintili alanlardır. Bir projede süre uzuyorsa bunun en akla yatkın nedeni kapsamın değişmesidir.
Gelelim macerama;
Çalıştığım şirkette bu aksaklıktan nasıl kurtulunabilir diye yaptığım araştırmalarda Agile/Scrum metodolojileri ile karşılaştım. Bunlar daha çok ekip halinde çalışan yazılımcıların takip etmesi gereken yöntemdi ve şirkette genelde bireysel projeler gerçekleşiyordu. Yani uygun değildi. Daha da Türkiye'de hiç duyulmamışlardı ve yöneticime kabul ettirmem imkansızdı. Aynı dönemde proje yönetimi konseptinin gelişmekte olduğunu gördüm. Yurtdışında pek çok sertifika programı başlamıştı. Kendi bütçemle yurtdışında bir haftalık kısa bir proje yönetimi eğitimine katıldım ve sertifikamı aldım ama tabii ki dünya çapında geçerli olan sınavına katılamadım. Şirketimde ise daha bırakın proje yönetimini, yazılım metodolojileri bile duyulmamıştı.
Geldikten sonra yöneticime aldığım eğitimi anlattım ve bu konuda uzmanlaşmak istediğimi söyledim. Bana yazılımcı olduğumu ve proje yönetiminin gereksiz olduğunu söyledi. Zaten beklediğim cevaptı. Teknolojinin ve konseptlerin Türkiye'ye gelmesini beklemeye karar verdim.
İlk gelen konsept adından mıdır bilmem Scrum oldu. Uygulanan kısmı sadece sabah toplantılarıydı ama nasıl olduysa eğitime bir arkadaşımızı göndermişlerdi ve kendisi de Scrum Master olduğu için çok umutluydu. Sonuç başarılı oldu mu bilemiyorum, ama proje gecikmelerindeki asıl soruna çözüm bu değildi. Bu süreçte bir ara pair programming yani çoktan terk edilen birlikte yazılım yapmak bile denendi. Avantajı vardı çalışmaya teşvik ediyordu. Hem denetçi hem denetlenen oluyordunuz ama aynı zamanda inanılmaz kaynak kaybıydı, o yüzden de yurtdışında hiçbir geçerliliği kalmamıştı. Bir şey demedim, izledim. Gelelim neden bir şey demediğime.
Çünkü hazır değillerdi. Bunu da yaşadığım bir örnekle açıklamak istiyorum.
Bana atanan bir iş akışı uygulamasında süre inanılmaz kısıtlıydı. Analiz yapılmamıştı. Doküman yoktu. Sadece bir danışmandan alınan bilgiler vardı. Analiz yapmaya bile vaktim yoktu, direkt kodlamaya geçmek zorunda kalmıştım. Bir yandan kodlama yapıyor, bir yandan her adımda doküman hazırlayıp, bu böyle gelecek, şu onay verecek buradan gidecek gibi bilgileri doğruluğundan emin olmak için iletiyordum. Tek bildiğim akıştı ve ekranla ilgili bilgileri ve fikirleri dahi olmayan iç müşteri benimle birlikte ekranlar şekillendikçe ne yaptığımızı anlamaya çalışıyorlardı. Gece gündüz mesailerle en azından akışın ilk adımını yetiştirmeye odaklanmıştım, en kolay kısmı da oydu ama alt yapısı, ekranları, bağlantıları, akış motoru da hazırlanmak zorundaydı. İnanılmaz stres altındaydım çünkü tüm üst yönetim ve tüm şirket projenin belirlenmiş olan bitiş tarihini bekliyordu. Bu süreçte yöneticime inanılmaz kızgındım, kapsamı belirlememişti, süreyi ayarlamamıştı, bunu yap demişlerdi o da aynen gelip bana bunu yap demişti. Büyük çaba ile ilk aşamayı tamamladık, ikinci aşamaya da başladım, bu arada testler devam ediyordu. Bilgisayarım ağırdı ve testler işkenceydi. İç müşteriyi yanıma oturtup test yapıyordum ki hemen müdahale edebileyim.  Derken ikinci aşamayı da tamamladım ve testlerini de bitirdik. Proje akışları 6 aşamadan oluşuyordu ve lansmanla beraber diğer aşamaları tamamlamayı umuyordum. Ben ilerlerken ve lansmana 3 gün kala iç müşteri gelip akışı değiştirdiklerini bildirdi. Yöneticime gittim ve o ne var küçük bir değişiklik istiyorlar işte dedi. Ben de açıklamaya çalıştım. Hiç unutmuyorum ona bir bina düşünün bunun birinci katını yıkıyorsunuz üst kısımları ayakta kalacak mı, tüm testler her şey yeniden yapılacak dedim. O da bana biz inşaat mühendisi değiliz dedi. Yani yöneticimin kapsam değişiminin önemine dair en ufak bir fikri yoktu, umursamıyordu da. Yine sinirlenmiştim ama bir şey demenin ne kadar manasız olduğunu anlamıştım.
İşte sorun buydu. Kapsamı değiştirirseniz projenin zamanını uzatırsınız, bu da bütçeyi etkiler, kaliteyi etkiler, başarıyı etkiler, daha da derinden incelerseniz insan kaynağınıza verdiğiniz değeri gösterir.
Yazılım projelerinde başarısızlığın nedenleri yönetimseldir. Analiz dökümanınız yoksa, kapsamınız doğru belirlenmemişse, kaynaklarınızı doğru atamamışsanız veya fazla iş yükü binmesine sebep olmuşsanız, projenizin bitişine ait bu kapsam bazında doğru zaman çizelgeniz hazırlanmamışsa yani proje planınız yoksa, başarısızlığa mahkumsunuz. Başarı projenin tamamlanması demek değildir. Kaynağınızı verimli kullanmanızdır, ürettiğiniz ürünün kalitesidir, ne yaptığınızı başından bilmeniz ve doğru çıktıyı elde ettiğinizden emin olmanızdır ve en önemlisi müşterinizin sonuçtan memnun olmasıdır. Yoksa uzaya mekik fırlatacak kadar kaynağınızla işlerinizi yetiştiremezsiniz.
Sonucu merak ediyorsanız; Fazla mesailerle iş odaklı olduğum için projeyi zamanında tamamladım ve başarılı bir proje olarak şirket bilgi işlem tarihine geçti ama benim açımdan proje yönetiminin önemini anladığım ve vizyoner bir bakış açısıyla çalışmam gerektiğini hissettiğim bir projeydi.
Tüm projelerinizde başarılar diliyorum.

21 Mayıs 2014 Çarşamba

MS SQL Views kullanımı - SQL CREATE VIEW

Veritabanı içinde "Views" alanı, hemen tablolarının "Tables" altında yer alır ve çoğu zaman kullanılmaz. Views içinde yaratacağınız View'lar ne işe yarar derseniz, uradaki oluşturacağınız sorgular dışarıdan sorgu yanıtını bir tablo gibi kullanmanıza yarar.
Genelde Stored Procedure'ler işimizi çözsede, "union all" komutu ile birleştirilmiş tablo yapılarına erişmek de fayda sağlar.

View nasıl oluşturulur?
Aşağıda bir iki tane örnek yazdım. Union kullanarak, direkt joinleyerek oluşturduğunuz tablolarla, veri setlerinizi oluşturmanız mümkün.

Yarattığınız View'u aynı bir tablo gibi
SELECT * FROM V_ORNEKVIEW 
şeklinde kullanabilirsiniz.

Temel yazım;
CREATE VIEW V_ORNEKVIEW 
AS
SELECT Alan(lar)
FROM TABLO1
WHERE KOSULLAR
GO

Union kullanımı;
CREATE VIEW [V_ORNEKVIEW]
AS
with VeriIsmi(Alan1, Alan2Alan3Alan4, Level)
as(
select x.Alan1, u.Alan2, u.Alan3, u.Alan4, 0 as Level
from TABLO1 u
LEFT join TABLO2 x ON u.Alan2= x.Alan2
WHERE u.Alan4 is not null

union all

select x.Alan1, u.Alan2, u.Alan3,  s.Alan4, Level+1 as Level
from TABLO1 u, TABLO2 x, VeriIsmi s
where u.Alan3 = s.Alan2
AND u.Alan2= x.Alan2
)
select ss.Alan1,ss.Alan2,ss.Alan3,ss.Alan4, ss.Level
from VeriIsmi ss
GO

JOIN kullanımı;
CREATE VIEW [V_ORNEKVIEW]
AS
select x.Alan1, u.Alan2, u.Alan3, u.Alan4, 0 as Level
from TABLO1 u
LEFT join TABLO2 x ON u.Alan2= x.Alan2
WHERE u.Alan4 is not null

GO

20 Mayıs 2014 Salı

Windows Mobile 6.0 kurulumu, TFS bağlantılarının yapılması ve uygulama geliştirme ayarları

Eğer Windows Mobile 6.0 ile uygulama geliştirmeniz, Team Foundation Server 2012'ye bağlanmanız ve de metwork üzerinde uygulamanızın çalışması gerekiyorsa, sırasıyla yapılması gereken kurulumlar aşağıda listelenmiştir.

1- Öncelikle Visual 2008 Kurulmalı
   SW_DVD9_Visual_Studio_Pro_2008_English_Core_MLF_X14-26326.ISO

2- Ardından Visual Studio 2008 SP1 kurulmalı
   VS2008SP1ENUX1512962.iso

3- Bunlardan sonra Team Explorer Kurulu tammalanmalı
   VS2008TeamExplorer.iso

4- Son olarak da GDR update for Visual Studio 2008 SP1 kurulmalı
   Bu TFS 2012 için destek ekliyor
   VS90SP1-KB2673642-x86.exe

5- Vindows Mobile Device Center 6.1 kurulacak

6- Windows Mobile 6 SDK (Professional) kurulacak

7- Virtual PC 2007 kurulacak (Handheld cihaz Emulatorunun network'e çıkabilmesi için
bu kurulumla gelen bir driver'a ihtiyaç var)

Kolay gelsin

web.config'den connectionstring veya başka bir genel kullanacağınız değeri almak

Öncelikle web.config içinde <appSettings> içine bağlantınızı veya değeri yazın.

<appSettings> <add key="myConnectionString" 
value="server=localhost;database=myDb;uid=myUser;password=myPass;" />
<add key="AppURL" value="http://localhost/"/> </appSettings>

Framework 3.5 ve sonrası için bağlantınızı <connectionStrings> içinde de 
yazabilirsiniz.

<connectionStrings>
<add name="myConnectionString" 
connectionString="server=localhost;database=myDb;
uid=myUser;password=myPass;" /> </connectionStrings>

Değerleri okumak içinse kodunuzda

string connStr = 
ConfigurationManager.ConnectionStrings["myConnectionString"].ConnectionString;

ve

string url = ConfigurationManager.AppSettings["AppURL"].ToString();

kullanabilirsiniz.

10 Kasım 2013 Pazar

ArrayList, Dictionary, List , Hashtable veri tipleri C#

//ArrayListArrayList liste = new ArrayList();
liste.Add("bir");
liste.Add("iki");
liste.Add(false);
foreach (var element in liste)
{
Console.WriteLine(element);
}

//Dictionary
Dictionary<string, int> dict = new Dictionary<string, int>();dict.Add("bir", 1);
dict.Add("iki", 2);
string veri = dict["bir"];
string veri2= dict["iki"];
//List
List<string> liste = new List<string>();
liste.Add("bir");
liste.Add("iki");
foreach (string element in liste)
{
Console.WriteLine(element);
}
List<string> liste = new List<string>();
liste.Add("bir");
liste.Add("iki");
foreach (string element in liste)
{
Console.WriteLine(element);
}
//Hashtable
Hashtable table = new Hashtable();
table["bir"] = 1;
table["iki"] = 2;
Hashtable table = new Hashtable();
table["bir"] = 1;
table["iki"] = 2;