Kategoriler


SON YORUMLAR
Ömer
Bloguma bi göz atar mısınız? Nasıl? bitkideryasi.blogspot.com
Ahmet
Hocam ben sorumsuz bi insanım ders çalışamıyorum yapımdan dolayı egitim sisteminden yakınıyorum bu meslek için gerekli olmayan dersleri bile görmekten hep nefret ediyorum. belki çok iyi bi üniverste kazanamayabilirim ama oldum olası bu iş benim işim diyorum yani bilgisayarda oyun oynamakdan başka yaptıgım bişey yok henüz lise ögrencisiyim ama bu işten başkada işim olamaz benim yani ortalama bir üniversite den mezun olarak kendimi geliştirebilirmiyim sizce?
Bilg. Müh.
Moloz
Atesh
Gercekten mukemmel yazilmis elinize saglik bende allahin izniye birinci sinif olucam bu sene cok tesekkur ederim
Tatar Ramazan
Benden başka yorum yazan yok ki. Çok sıkııcı!..Bilgisayar mühendisliğini kimse umursamıyor site sahibinden başka..vah vah
Tatar Ramazan
LINQ to XML var sorgu = from fakulte in fakulteler.Descendants("Fakülte") from bolum in bolumler.Descendants("Bölüm") from ogrenci in ogrenciler.Descendants("Öğrenci") where (int)ogrenci.Element("bno") == (int)bolum.Element("bno") && (int)fakulte.Element("fno") == (int)bolum.Element("fno") group fakulte by new { Fadı = fakulte.Element("fadı").Value } into fgrup where fgrup.Count() b= (from bolum in bolumler.Descendants("Bölüm") from ogrenci in ogrenciler.Descendants("Öğrenci") where (int)ogrenci.Element("bno") == (int)bolum.Element("bno") group bolum by bolum.Element("fno").Value into bgrup select bgrup.Count()).Max() select new { _fakultead = fgrup.Key.Fadı, }; ListkOgrenciTablob liste = new ListkOgrenciTablob(); foreach (var item in sorgu) { liste.Add(new OgrenciTablo { Fakulte = item._fakultead }); }
Tatar Ramazan
Bilişim Uzmanlığım Aşağıdadır : Programlama Dili : C#, Java, ASP.NET, Silverlight, WPF, WCF, LINQ, XML, XSL, HTML, Javascript, CSS, JQuery, Ajax, Web Servisleri. Veritabanı : SQL Server, T-SQL, ADO.NET, Oracle 11g-PL/SQL, Reporting Services. Metodoloji : Nesne Yönelimli Programlama ve Üç Katmanlı Mimari Program : Ms Office, Adobe Reader. KPDS (Kamu Personeli Dil Sınavı) (89 Puan) 12.2010 YDS (Yabancı Dil Sınavı) (72 Puan) 09.2015 C# : Fundamentals of Programming, Functions, Object-Oriented Programming, Class, GUI Programming, Recursion, LINQ, Event-Delegate, Collections-Generic, Windows Forms, XML, File-Directory, Date Time, Reflection, WPF, WCF, Ado.Net, vs.. ASP.NET : Silverlight, Asp.Net-Html Controls, Response, Sessions, Cookie, Roles and Profiles, Configuration, Data Binding, Page Lifecycle, Validation, Authentication, Authorization, HttpWebRequest, Communication between Silverlight and Javascript vs.. TRANSACT SQL : SQL, View, Procedure, Function (scalar, table-valued), Trigger, Transaction, Index, Constraints, Cursor, String Functions, Analytical Functions, Data Convert Functions, T-SQL commands (If, Else, While vs), Set operations, Sequence Identity, Handling Errors vs..
Tatar Ramazan
Bilişim kadar güzel meslek mi var. Her yerinden meslek, uzmanlık fışkırıyor. Ofis programları mı dersin, .NET, Oracle, Java mı dersin, sistem-network mü dersin, Grafikerlik mi dersin, Çizim programları mı dersin...Gıcır gıcır renkli teknolojiler..Yaptığın ürünü iç piyasaya satamazsan yurtdışına satarsın..Gençler için yığınla iş ve uzmanlık alanı. Oturun çalışın işte..Hem para hem keyif...java2s.com diye site var..Bütün teknolojilerin bütün konularıyla ilgili A dan Z ye örnek koymuş adamlar. Bizim öğrenciliğimizde yoktu...Oturun çalışın bahane üretmeyin. Yeniden görüşüciiz...
EZS
Paylaştığınız bilgiler için teşekkürler. qushevaksesuar.blogspot.com
77.245.150.214
Amacım bu dünyaya yararlı olabilmek.Biliyorum derslerim kötü ama insan hedefine ulaşmak için elinden geleni yapar.Lise 3.sınıf öğrencisiyim evet çok kafam çalışmayabilir ama bu çalışmıcak anlamına gelmez.İnsan kendini geliştirebilir.Bu makale için çok teşekkür ederim.Gerçekten bakış açım değişti ve bir genci daha kurtardınız.İlerde iyi bir yere gelirsem unutmuyacağım.Cümleleri yazarken biraz saçmalamış olabilirim her neyse ADIMI IP niz yapıverdim. İLERDE ŞUNU DEMEK İSTİYORUM ZİRVEDEYİM CANIM DUYULMUYOSUN.:D
Tatar Ramazan
Kaç zamandır bilgisayar mühendisliğine saldırıyorum site sahibi ağzını açıp mesleğini savunamıyor. Sükut ikrardan gelir tabi..
Nur
Dokuz eylül ve özyeğin arasında kaldım. Lütfen yardım edin . Bana katkıları eğitimi iş olanağı vs açısından sizce hangisini seçmeliyim
Tatar Ramazan
Başlarım sizin boğaziçinize de bilkentinize de odtünüze de.. hiç biri bi bok olamıyor. Ali AĞAOĞLU gibi hödükler malı, kızları götürüyor. Millet sevgilisiyle fink atar siz de abaza abza gezersiniz. Mezun olunca da kızlar zıpırları tercih edecek zaten size vermeyecekler. Her şey görüntü bu devirde, diplomanız bi boka yaramaz. Kocaeli elektroniği bitirmiş bi adam vardı. 28 yaşında işsiz olarak askere gitmişti.
From Tatar Ramazan To Boun
He he kolaydı öyle kendi işini kurmak. Kolay olsaydı insanlar devlete ve özele girmek için birbirlerini ezercesine yarışmazlardı. Mezun olunca bilg. mühendisliğini, yazılımı övenlere, size boş vaatler sunanlara gıcık olacaksınız merak etmeyin. 70 bin bilişim uzmanı varmış, yok güzel meslekmiş de bilmem ne. Hepsi palavra. 10 tane teknolojiyi A dan Z ye biliyor olmama rağmen hala beni mülakatta afra tafra yapıyorlar diyorum anlamıyor musunuz? Bizim kuruma canavar gibi yazılımcılar özelden kaçtı geldi. 7-10 yıllık deneyimli olanlar bile. Ege mezunu, ODTÜ mezunu ilk 2000 girmiş adamlar vs.. Zamanında memur olduk da yırttık. Özel firmaların kucağına düştün yandın. Yanlış konuşuyorsam çevrenizden 30 yaş üstü yazılımdan köşeyi dönen adamları gösterin bana o zaman..Yeniden görüşüciiz.

Bilgisayar Mühendisleri
Here is the website inspired me to use 
it as a guide when I tried to define 
myself as an engineer candidate a few 
years ago. It really helped me to work
 and study feeling in confidence with 
being on the right way. I suggest this 
website to whom it may direct her/his 
to find the right career path. It 
includes many articles varies from 
real life experiences to detailed 
software engineering issues. But the 
most dignified parts for me are the 
articles in general and career titles.
Son okunan makaleler:
NHibernate ile ORM'e Giriş
Kim neyi niye seçer? Java mı c# mı? Oracle vs SqlServer?
Kim neyi niye seçer? Java mı c# mı? Oracle vs SqlServer?
Online Java Dersleri - Polimorfizm
Java'nın kurucusu Google'a transfer oldu
Neden Bilgisayar Mühendisliği?
Üniversitelerin akademik yayın karşılaştırması
Facebook Developer Toolkit ile Örnek Program
AJAX ve Şahane Ajax Örnekleri
Akıllı İstemci & Web Uygulamaları
Yazılım Mühendisliği ve Bilgisayar Mühendisliği arasındaki farklar
Introduction to making multithreaded VB.NET Apps
Bilgisayar mühendisliği öldü?
Online Java Dersleri - Interface and Inner Classes
Windows Workflow Foundation Conditions
C#: Nitelikleri Kavramak (Attributes)
Bir bakışta Java ve C# karşılaştırması
Windows Workflow Foundation'a Giriş
SQL Server - SP için önemli ipuçları
SSIS’ in güzellikleri 1

Bilgisayar Mühendisleri Portalı

NHibernate ile ORM'e Giriş

Hakia.com’un iş ilanlarındada görmeye başladığımız NHibernate sizce nedir?

Dosya adı: ogrenci.cs
--------------------------------
using System;
using System.Collections.Generic;
using System.Text;

namespace ormornek
{
         class ogrenci
         {
                  private int _id;
                  private string _ad;
                  private string _soyad;

                  public int Id
                  {
                           get { return _id; }
                           set { _id = value; }
                  }

                  public string Ad
                  {
                           get { return _ad; }
                           set { _ad = value; }
                  }

                  public string Soyad
                  {
                           get { return _soyad; }
                           set { _soyad = value; }
                  }
         }
}

 

NHibernate ile hiç SQL komutu yazmadan veritabanı işlemleri yapabiliyoruz dersem çok abartmış olduğumu düşünebilirsiniz. Fakat şaşılacak şekilde NHibernate ile projelerimizde SQL komutu kullanmaya gerek kalmıyor. Verilerimizi, yine projemiz içerisindeki nesne modelleri ile bağlayıp veritabanına taşıyabilmekteyiz. NHibernate çok katmanlı mimaride orta katman(business logic) dediğimiz kısımda yapılan veritabanı işlemlerinde büyük kolaylıklar sağlamaktadır. Bu makale NHibernate’i en basit şekliyle .NET kullanıcılarına tanıtmak amacıyla yazılmıştır.
Bu günün kurumsal uygulamalarında nesne tabanlı ve ilişkisel veritabanı kullanılarak yazılım geliştirmek can sıkıcı hatta çok zaman alıcı bir iş olmaktadır. NHibernate .NET yazılım geliştirme ortamında nesnel/ilişkisel eşleştirme(object/relational mapping-ORM) aracıdır. ORM terimi bir nesne modelinden SQL tabanlı ilişkisel veri modeline(ilişkisel veritabanına) veri bağlama tekniğidir.

Çoğu kişi makaleyi okuduk’dan sonra NHibernate’i C# 3.0 la birlikte gelen DLINQ mimarisine benzetebilir ve bunda yanılmışta sayılmaz. Çünkü ikisinde de amaç hemen hemen aynıdır.

Bu kadar sözün ardından basit bir uygulama yaparak NHibernate’i tanıyalım.

Öncelikle aşağıdaki işlemleri yapmanız gerekmektedir.

http://sourceforge.net/project/showfiles.php?group_id=73818&package_id=138561 web adresinde “NHibernateContrib” adlı zip dosyasını download ediniz.


---------------------------------------------------------------------------------------------------
“NHibernateContrib” adlı zip dosyasını ana dizininiz içerisinde istediğiniz bir konuma açınız.


---------------------------------------------------------------------------------------------------
Bu işlemleri yaptıkdan sonra VS içerisinde New->Project->Console Application yolunu izleyerek “NHibernate“dışında bir isim vererek yeni bir proje açın. Bu örnekteki projeye “ormornek” adını verdik. Bu ad daha sonraki işlemlerde veritabanına bağlantı sırasında kullanılacakdır.
---------------------------------------------------------------------------------------------------
Yeni projeyi oluşturdukdan sonra projemize yeni bir class ekleyelim. Yeni class dosyasının adı ile class adı aynı olsun.(örneğin; dosya adı: ogrenci.cs ve class adı:ogrenci) Ben burada class adına “ogrenci” dedim. ogrenci class’ının içeriği aşağıdaki gibi olacak.

Timuçin Dursun

Ogrenci class’ını oluşturduk dan sonra veritabanımızda bu nesne modeline uygun bir tablo oluşturmamız gerekli. Bu tablo ve veritabanı adına dikkat ediniz. Gerekli kodlar,

CREATE TABLE [dbo].[ogrenci](
[id] [int] NOT NULL,
[ad] [nvarchar](50) NULL,
[soyad] [nvarchar](50) NULL
)

Not: veritabanı için MSSQL 2005\SQL EXPRESS kullanıldı.
---------------------------------------------------------------------------------------------------
Şimdi en önemli kısımlardan biri olan ORM bağlama işlemini yapacağız. Öğrenci nesne modelimiz ile ilişkisel veritabanındaki veri yapımızı birbirine bağlıyacak olan NHibernate konfigürasyon dosyasını düzenleyeceğiz. Bu dosyaya mapping file yada Türkçe adıyla eşleştirme dosyası diyebiliriz.

Projemizin ana dizinine “ogrenci.hbm.xml” adlı bir xml dosyası oluşturalım. NHibernate te kullanılan mapping dosyalarının uzantıları genellikle “*.hbm.xml” dir. Ayrıca bu dosyaya solution explorerdan sağ tıklayıp properties’ine girdikden sonra built action özelliğini “Embedded Resource” yapmamız gerekmektedir. Eğer bunu yapmaz iseniz büyük ihtimalle hata mesajı ile karşılaşırsınız.



Xml dosyasının içeriği de aşağıdaki gibi olsun.

Dosya adı: ogrenci.hbm.xml
--------------------------------

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.0">
<class name="ormornek.ogrenci, ormornek" table="ogrenci">
<id name="Id" column="id" type="int">
<generator class="assigned" />
</id>
<property name="Ad" column="ad" type="String" length="50"/>
<property name="Soyad" column="soyad" type="String" length="50"/>
</class>
</hibernate-mapping>

Dosya içeriğindeki <class> tag’ında
<class name="[namespace].[class name], [assembly name]” table=”tablename”> sırası izlenmektedir.

Şimdi sıra geldi projemize App.config dosyasını eklemeye. Bu işlemi solution Explorer penceresine sağ tıklayıp ->Add->New Item->Application Configuration File yolunu izleyerek yapabiliriz. App.config dosyası solution Explorer penceresinde gözüküyor olmalı. App.config dosyası içerisinde <configuration>...</configuration> tagları arasına aşağıdaki kodları yazdığımızda veritabanı bağlantısı için gerekli işlemleride yapmış oluruz. (Bu uygulamada MSSQL 2005-SQLEXPRESS kullanılmıştır.)

Bu dosya içerisindeki <nhibernate>…</ nhibernate> tagları arasındaki parametreler veritabanı bağlantısı için gereklidir ve opsiyoneldirler. Kullanmak istediğiniz yada başka değişle bağlantı kurmak istediğiniz veritabanına göre değişiklik gösterebilirler.

Dosya adı: app.config
-------------------------------------------------------------------

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section
name="nhibernate"
type="System.Configuration.NameValueSectionHandler, System, Version=1.0.5000.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"
/>
</configSections>

<nhibernate>
<add
key="hibernate.connection.provider"
value="NHibernate.Connection.DriverConnectionProvider"
/>
<add
key="hibernate.dialect"
value="NHibernate.Dialect.MsSql2000Dialect"
/>
<add
key="hibernate.connection.driver_class"
value="NHibernate.Driver.SqlClientDriver"
/>
<add
key="hibernate.connection.connection_string"
value="Data Source=TIMUCIN\SQLEXPRESS;Initial Catalog=timucin;Integrated Security=True"
/>
</nhibernate>
</configuration>

En işlemlerden biride NHibernate.dll kütüphanesini projemize eklemektir. Solution explorer penceresinde references üzerine sağ tıklayıp->add references-> yolunu izleyerek “NHibernateContrib” adlı zip dosyasını açtığımız dizinin içinde bulunan bin dizininin içine gireriz. Bin dizini içerisindeki NHibernate.dll dosyasını projemize referans olarak ekleriz.

Son işlemimiz olarak main fonksiyonumuzun bulundugu class’ı yani program.cs dosyamizin icine aşağıdaki kodu yazarak asıl yapmak istedigimiz işi gerçekleştirmiş oluruz.

Aşağıdaki kod ile veritabanına 3 kayıt eklenip 1 kayıt silinmektedir.

Ayyrıca burada dikkat etmeniz gereken bir husus daha bulunmaktadır. Program.cs dosyasına

using NHibernate;
using NHibernate.Cfg;

namespace’lerini eklemeyi unutmamalısınız.

//Dosya adı: program.cs
using System;
using System.Collections.Generic;
using System.Text;

using NHibernate;
using NHibernate.Cfg;

namespace ormornek
{
      class Program
      {
            static void Main(string[] args)
            {
                  Configuration cfg = new Configuration();
                  cfg.AddAssembly("ormornek"); // projenin assembly adı

                  ISessionFactory factory = cfg.BuildSessionFactory();
                  ISession session = factory.OpenSession();
                  ITransaction transaction = session.BeginTransaction();

                  ogrenci ogr1 = new ogrenci();
                  ogr1.Id = 1;
                  ogr1.Ad = "timuçin";
                  ogr1.Soyad = "dursun";

                  ogrenci ogr2 = new ogrenci();
                  ogr2.Id = 2;
                  ogr2.Ad = "bahar";
                  ogr2.Soyad = "dursun";

                  ogrenci ogr3 = new ogrenci();
                  ogr3.Id = 3;
                  ogr3.Ad = "tufan";
                  ogr3.Soyad = "dursun";

                  // NHibernate nesne örneğini sql komutu kullanmadan veritabanına kaydediliyor.
                  session.Save(ogr1);
                  session.Flush();// nesne veritabanına yollanıyor
                  session.Clear();// baska nesneyi oturuma almak icin onceki siliniyor

                  session.Save(ogr2);
                  session.Flush();
                  session.Clear();

                  session.Save(ogr3);
                  session.Flush();

                  // NHibernate nesne örneğini sql komutu kullanmadan veritabanından siliyor.
                  session.Delete(ogr3);                  

                  // tüm değişiklik doğrulanıyor ve oturum kapatılıyor.
                  transaction.Commit();
                  session.Close();

                  // kaydedilen veriler veritabanından okunuyor
                  session = factory.OpenSession(); // yeni bir oturum açılıyor

                  System.Collections.IList userList = session.CreateCriteria(typeof(ogrenci)).List();

                  foreach (ogrenci ogr in userList)
                  {
                          Console.WriteLine("Id:{0} \t ad:{1} \t soyad:{2}", ogr.Id,ogr.Ad,ogr.Soyad);
                  }

                  session.Close();
           }
      }
}

Programı derlediğiniz zaman bir hata mesajı ile karşılaşmaz iseniz veritabanına 2 tane kayıt yapılmış olduğunu göreceksiniz.

Solution explorer görünümü

Makalemizin sonuna gelmiş bulunuyoruz. İşlemler çok uzun gibi gözüksede alışkanlık edindikten sonra SQL komutları kullanmadan veriler üzerinde işlem yapmanın keyfine doyamıyacaksınız. NHibernate geleceğin ORM tekniği ile veritabanı kullanım yöntemidir.
Bu teknik ile geliştirmiş olduğunuz projelerde veritabanı işlemlerini kolaylıkla yapabilirsiniz.Ayrıca gelecekde doğabilecek değişikliklerin üstesinden çok hızlı ve etkin bir şekilde gelebilirsiniz.

Microsoft tarafında ORM teknolojisinin karşılığı olarak DLINQ geliştirilmektedir.( Burak Selim Şenyurt ’un “C# 3.0 - İlk Bakışta DLINQ” makalesinde detaylı bilgi bulabilirsiniz )

NHibernate ile ilgili daha ayrıntılı bir makale ile görüşmek dileğiyle.

Gerekli dokümanları ve ayrıntılı bilgiyi aşağıdaki web adresinde bulabilirsiniz.

http://www.hibernate.org/365.html

Bu makaleyi beğendin mi? Yorumunu Yaz!







Sizden Gelen Yorumlar:

Yorum Yazın

oğuz karababa(06.06.2016 19:42:23)
Peki timucin bey bunlar gerçek hayatta nerde işimize yarayacak.
%50 %50 %0
Katılıyorum Çekimserim Katılmıyorum



Ahmet Uğur(21.09.2010 18:10:14)
Güzel yazı ancak Nhibernate e girmek nasip olmadı hata almaktan dolayı. google da bakarken birisi aynen sole yazmıs
Why is it so hard to get NHibernate to work?... :D
%60 %20 %20
Katılıyorum Çekimserim Katılmıyorum






Copyright© 2001-2017. Bilgisayar Mühendisleri Portalı | Bütün hakları saklıdır.