• Anasayfa
  • Hakkımızda
  • Etkinlikler
  • Destek Verin
  • Site Haritası
  • Giriş Yap
  • Üye Ol
  • Facebook
  • Twitter
  • RSS
Yazılım Dilleri
  • Soru - Cevap
  • EĞİTİM SETİ
  • KATEGORİ
  • DUYURU
  • TEKNOLOJİ HABERLERİ

Son Sorular

  • 8/2/2020 11:38:31 PM'Basit' Yazılım Dili
  • 6/25/2020 3:18:13 PMderleme hatası
  • 12/11/2017 4:49:15 PMWindows Hizmeti Hk.
  • 4/23/2016 12:55:33 AMC programlama 2 oyun

Popüler Sorular

  • 5/27/2012 5:49:50 AMAsp.Net ile Date time alana veri ekleyemiiyorum ?
  • 4/2/2012 12:45:18 AM.exe uzantılı dosya için dijital imza nerde nasıl alınır.
  • 5/12/2012 8:44:49 AMAcil Yardım
  • 5/27/2012 1:46:51 PMveri tabanı bağlantısı
  • .Net Framework
  • 8085 Assembly
  • Active Directory
  • ADO.NET
  • Android
  • Apple IOS
  • Arduino
  • ASP.NET
  • ASP.NET MVC
  • Blackberry
  • C#.Net
  • C++
  • CCG Framework
  • CISCO
  • CSS
  • Diğer
  • Dreamweaver
  • Entity Framework
  • Exchange Server
  • Gömülü Sistemler
  • GSM Programlama
  • Güncel
  • Güvenlik
  • HTML5
  • Java
  • Javascript / JQuery
  • Jira
  • Kariyer ve İş Yaşamı
  • LibreOffice
  • LINQ
  • Linux
  • Matlab
  • Microsoft Dynamics CRM
  • Mobil Uygulama Geliştirme
  • MySQL
  • NoSQL
  • Oracle
  • OWIN
  • PFSense
  • PHP
  • Powershell
  • Python
  • Sanallastirma
  • SAP-ABAP
  • SCOM 2012
  • SEO
  • Sharepoint 2010
  • Sharepoint 2013
  • Silverlight
  • Sistem Analiz ve Tasarımı
  • SQL Server
  • Symantec
  • TFS
  • T-SQL
  • Ubuntu
  • VB.NET
  • Veritabanı Yönetim Sistemleri
  • Visual Studio
  • VMware
  • WCF
  • Web Hosting
  • Windows 8
  • Windows Azure
  • Windows Phone 7.1
  • Windows Phone 8
  • Windows Server
  • Wordpress
  • WPF
  • Xamarin
  • XNA
  • Yazılım Mühendisliği
  • Yöneylem Araştırması
  • ASP.NET MVC
  • Entity Framework
  • Javascript / JQuery
  • LINQ
  • PHP

Son Duyurular

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

WP'da Veri Tabanı-1(Veri Tabanı Model ve Görünümünün Oluşturulması)

1.Veri Tabanı Model ve Görünümünün Oluşturulması Bu bölümde veri saklama konusunda önemli bir yer tutan ve Windows Phone 7 nin Isolated Storage ‘ini kullanarak veri tabanı oluşturma ve veri tabanı iş

10.07.2012

Yazar: Nagihan Sema KUDU (Google+)

Kategori: Windows Phone 7.1

5184
 

 

Bu bölümde veri saklama konusunda önemli bir yer tutan ve Windows Phone 7 nin Isolated Storage ‘ini kullanarak veri tabanı oluşturma ve veri tabanı işlemlerini öğreneceğiz.Kullanıcın istediği sayıda alış-veriş listesi tutabileceği ,bu listelere ürünler ekleyebileceği,fiyatları girilen ürünlerin fiyatlarını toplayarak o anki listedeki alışveriş maliyetini gösterebilecek,kullanıcın sevdiği ürünleri saklayabileceği gibi bir çok özelliği olan bir uygulama yaparak Windows Phone 7 de veri tabanı işlemlerine giriş yapalım.

Bu uygulamada en önemli kısım alışveriş listeleri sayısının kullanıcıya bağlı olarak oluşturulması yani dinamik olarak oluşturulmasıdır tabiî ki bu durum ek bazı işlemler gerektirir.Veri tabanı oluşumunda gerçekleştirdiğimiz sorgular LINQ To SQL sorgularıdır ve veri tabanı oluşumunda DBDataContext.cs sınıfı ile database modelini belirlenirken yani databasedeki tablolar,tabloların sahip olduğu sutunlar,yabancı anahtar vb. tanımlamaları yer alırken,ikinci olarak oluşturacağımız DBView.cs sınıfında da LINQ to SQL sorguları ve bu sorgularla oluşturacağımız ObservableCollection oluşumları,bu koleksiyonları kullanarak add,delete vb. metodları yer alacaktır.Bu veri tabanı metodları kullanılarak örneğin AddNewProduct vb. ile ileride oluşturacağımız sayfalarda ürün,liste,mağaza gibi elemanları veri tabanına ekleyip silebileceğiz.

Yeni bir Silverlight for Windows Phone projesi oluşturalım ve MyShopping olarak adlandıralım,proje yaratıldıktan sonra Solution Explorer’de projeye sağ tıklayarak Add Reference ile bazı  referansları projeye ekleyelim:

 

Add Reference->Browse ile karşımıza çıkan tab menüden  Microsoft.Phone.Controls.Toolkit.dll ‘yi ekleyelim artık Reference klasöründe  Microsoft.Phone.Controls.Toolkit.dll assembly ‘si gözükecektir. İkinci referansımız ise Add Reference ->.NET tabı dan  System.Data.Linq ‘i seçmek olacaktır. Aynı bölümden pivot sayfaları kullanabilmek için Microsoft.Phone.Controls  referansı da seçilerek projeye eklenir.

Bu işlemlerden sonra artık database modelimzi oluşturabilirz bunun için DBDataContext.cs sınıfını oluşturalım yine projemize sağ tıklayıp Add-> New Item diyerek bir class oluşturup ismini  bu şekilde belirleyelim. Sınıfı oluşturduktan sonra ilk olarak veri tabanı Connection String tanımlaması yapmalıyız. Daha sonra tablo tanımlamalarımızı yapıp tablo sütunlarını oluşturabiliriz.

 

 

 

   public class DBDataContext : DataContext

    {

        // Pass the connection string to the base class.

        public DBDataContext(string connectionString)

            : base(connectionString)

        { }

 

        //Table for shopping products

        public Table<TProduct> Products;

 

        // List of shopping products'

        public Table<TList> PLists;

 

        // Table for shopping products' store

        public Table<TStore> Stores;

    }

 


Bu tanımlamadan sonra sıra tablo sütunlarının sütun özelliklerini ve yabancı anahtarları belirlemeye gelir.

Ürünler tablosu için örnek sütun aşağıdaki şekilde yapılır ve bu  sütuna Primary Key,Not Null Identity gibi  özellikler de atanmıştır.

 

 

 

public class TProduct : INotifyPropertyChanged, INotifyPropertyChanging

    {

 

        private int _ProductId;

 

        [Column(IsPrimaryKey = true, IsDbGenerated = true, DbType = "INT NOT NULL Identity", CanBeNull = false, AutoSync = AutoSync.OnInsert)]

        public int ProductId

        {

            get { return _ProductId; }

            set

            {

                if (_ProductId != value)

                {

                    NotifyPropertyChanging("ProductId");

                    _ProductId = value;

                    NotifyPropertyChanged("ProductId");

                }

            }

        }

 



Tablonun diğer sütunları ve özellikleri  benzer şekilde tanımlanır.Ürünler tablosunda yer alan diğer sütunlar:

[Table]   TProduct

string ProductName

string ProductStore

decimal Price

bool IsLiked

int _PListId

 

benzer mantıkla Listeler tablosu ve Mağazalar tablosu da oluşturulur.Listeler tablosunda:

[Table]  TList

int Id

string Name

bool Checked

 

 kolonları vardır Mağazalar tablosunda mağaza Id ve ismi kolonları yer alır:

 

[Table]  TStore

int SId

string StoreName

 

 

Listeler tablosu ile Ürünler tablosu arasında yabancı anahtar(foreign key) ilişkisi vardır.Bu ilişki şu şekilde sağlanır.

 

 

 

İlk olarak TProduct tablosunda aşağıdaki ilişkilendirme yapılır:

 

 

[Column]

        internal int _PListId;

 

        private EntityRef<TList> _tlists;

 

        [Association(Storage = "_tlists", ThisKey = "_PListId", OtherKey = "Id", IsForeignKey = true)]

        public TList TListx

        {

            get { return _tlists.Entity; }

            set

            {

                NotifyPropertyChanging("TListx");

                _tlists.Entity = value;

 

                if (value != null)

                {

                    _PListId = value.Id;

                }

 

                NotifyPropertyChanging("TListx");

            }

        }



 

Bu tanımlamada TProduct tablosundaki int _PListId ile TList tablosundaki Id arasında bir yabancı anahtar ilişkisi oluştuğu belirtilir benzer şekilde TLists tablosunda aşağıdaki ilişkilendirme yazılır.

 

 

 

private EntitySet<TProduct> _plists;

 

        [Association(Storage = "_plists", OtherKey = "_PListId", ThisKey = "Id")]

        public EntitySet<TProduct> Mshop

        {

            get { return this._plists; }

            set { this._plists.Assign(value); }

        }

 



TList tablosunda buna ek olarak add ve remove işlemlerinde tablodaki verilerin senkronize olması için aşağıdaki kodlar gereklidir.


        // Assign handlers for the add and remove operations, respectively.

        public TList()

        {

            _plists = new EntitySet<TProduct>(

                new Action<TProduct>(this.attach_Mshop),

                new Action<TProduct>(this.detach_Mshop)

                );

        }



 

        // Called during an add operation

        private void attach_Mshop(TProduct Mshopx)

        {

            NotifyPropertyChanging("TProduct");

            Mshopx.TListx = this;

        }

 

        // Called during a remove operation

        private void detach_Mshop(TProduct Mshopx)

        {

            NotifyPropertyChanging("TProducts");

            Mshopx.TListx = null;

        }

 


Veri tabanını modelini bu sınıfla oluşturmuş olduk daha sonraki adımda veri tabanı görünümün için yeni bir sınıf oluşturacağız, görüşmek üzere ,iyi çalışmalar :)

 

Oluşturulan sınıf burada :)

Yazar Hakkında

Nagihan Sema KUDU

Nagihan Sema KUDU

www.semakudu.com

Karadeniz Teknik Üniversitesi Bilgisayar Mühendisiliği bölümü mezunuyum,çok küçük yaşlardan beri müzik ve resimle uğraşıyorum,2011 Microsoft yaz okulu ile başlayan serüvenim,Microsoft Student Partner olarak devam etti.2013 yılında Nokia Developer Champion oldum.Windows Phone ile ilgili verdiğim bir çok eğitim var.Silverlight,.NET,Görüntü ve Ses İşleme,Windows Phone,Oyun Programlama,Windows8,Java,Android,UI,UX ile ilgilenmekteyim.

Sosyal Medya

ORANLAR

  • 5184izleme

Arkadaşlarınla Paylaş

  • Tweet

0 Yorum

Yorum Yaz / Soru Sor

Lütfen yorum yazmak veya soru sormak için üye girişi yapınız.

Son Yorumlar

  • Böyle bir sayfalama ağ trafiğini hafifleti...
  • Böyle bir sayfalama ağ trafiğini hafifleti...
  • Merhaba, ellerinize sağlık çok yardımcı ol...
  • Merhaba Bu uygulama örneğinden ASP.net ...
  • Hocam Link başka sayfaya yönlendiriyor.

En Güncel Sorular

  • Bilgilendirme maili (C#.Net)
  • Power Pivot (Sharepoint 2010)
  • BigInteger, BigDecimal (Asp.Net ve Asp.Net MVC)
  • visual C# ile asp nette veritabanı islemleri (Asp.Net ve Asp.Net MVC)
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ? (Sharepoint 2010)

En Son Cevap Verilen Sorular

  • Bilgilendirme maili
  • BigInteger, BigDecimal
  • visual C# ile asp nette veritabanı islemleri
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ?
  • txt dosyasına veri yazma

Twitter

Takip et: @yazilim_dilleri

En Çok Okunanlar

Elif BAYRAKDAR

C# ile SQL Server Bağlantısı, Insert, Update ve Delete Sorguları

23.05.2013

  • 131423
  • 0
Hakan Keskin

C# ile Windows Service Projesi Oluşturma, Debug Etme ve Setup Hazırlama

17.12.2013

  • 78711
  • 0
batuhan avlayan

Php - Mail Gönderme (İletişim Formu)

02.09.2013

  • 52141
  • 0

Sponsorlar

KODLAB
Pluralsight
Exchange server is
Office 365
YAZILIM DİLLERİ
Yukarı Çık
  • Hakkımızda
  • Facebook
  • Twitter
  • RSS

© Yazılım Dillerinin Buluşma Noktası | Kaynak belirtildiği sürece makaleler kopyalanabilir.
YazilimDilleri.Net sitesinde yer alan kullanıcıların oluşturduğu tüm içeriklerin yayınlanması ile ilgili yasal yükümlülükler içeriği oluşturan kullanıcıya aittir, YazilimDilleri.Net hiçbir şekilde sorumlu değildir.

Kapat

Giriş Yap

Kullanıcı Adı

Şifre

Şifremi Unuttum

KULLANICI GİRİŞİ