$show=home

Veri Tabanı Tablolarını Okuma ve Görüntüleme (WRITE, ULINE, SKIP Komutları)

Veri Tabanı Tablolarını Okuma ve Görüntüleme Bir raporda veritabanı tabloları ile çalışmak istediğinizde, raporda tablodan gelen verile...

Veri Tabanı Tablolarını Okuma ve Görüntüleme

Bir raporda veritabanı tabloları ile çalışmak istediğinizde, raporda tablodan gelen verileri düzenleyebileceğiniz bir çalışma alanı (work area) bildirmeniz gerekir. Bizim ZMEMBER01 tablomuz için aşağıdaki ifadeyi kullanarak bunu yapabilirsiniz:

DATA wa_zmember01 TYPE zmember01.

DATA ifadesi programda veritabanı tablosu ile aynı veri türüne sahip ve aynı adı taşıyan bir yapı oluşturur : Çalışma Alanı (Work Area)
ABAP ile ilgili yayınlar birbirlerini takip eden konular içerir. Tüm ABAP yayınlarının listesine ulaşmak için tıklayınız.
Bu yapının tüm alanları veritabanı tablosundaki alanlar ile aynı adlara ve veri türlerine sahiptir. Veri tabanı tablosundan veri kayıtlarını okurken, veri kayıtlarının her birini yapının içine koyabilir ve sonra onlarla çalışabilirsiniz.
  • [message]
    • Kullanılmayan TABLES İfadesi
      • Eski programlar tablo alanı veya tablo çalışma alanını tanımlayan ve artık kullanılmayan TABLES ifadesini içerebilir. Bu ifade programda başvurulan veritabanı tablosu için aynı isimde bir veri yapısı (data structure) oluşturur. Veritabanı erişimi için bazı komutların, çalışma alanının (work area) açıkça belirtilmediği kısa biçimleri vardır. Açıkça adlandırılmış bir çalışma alanı kullanmak yerine, sistem örtülü olarak ABAP Sözlük’teki veritabanı tablosu ile aynı ada sahip bir çalışma alanı oluşturur. Bu karışıklığa ilaveten, bu tür örtük adlandırılmış çalışma alanlarının adları yanlış kullanım sonucu, sık sık diğer veri nesnelerine (data objects) verilir. Bu durum ise kafa karıştırıcı olabilir. Çünkü programı okuyan kişi için kodun ne zaman bir çalışma alanını (programınızın belleğinde bir veri nesnesi), ne zaman bir veritabanı tablosunu ve de ne zaman sadece söz konusu veritabanı tablosunun sözlük yapısını ifade ettiği açık değildir. Söz konusu ABAP komutlarının kısa biçimleri bu üçü arasında hiçbir fark belirtmez. Normal koşullarda, eğer bu tip artık kullanılmayan ifadeler kullanırsanız programlama ortamı hata verir. Eski programlarda bu tip ifadeleri bulacak olsanız bile, bunları kullanmayı alışkanlık haline getirmemelisiniz.
    • Tire
      • Yapıların alanlarını çalışma alanının ismi ve çalışma alanındaki alanların isimleri ile belirtirsiniz; örneğin WA_ZMEMBER01 çalışma alanının MNAME alanını WA_ZMEMBER01-MNAME olarak belirtirsiniz. Adın ilk bölümü çalışma alanı yapısının adıdır; ikinci bölüm ise alan adıdır. Herhangi bir boşluk olmaksızın adın bölümlerini ayıran tire işaretine dikkat edin. Gelecek çalışmalarınızda da, tire işaretinin sadece bu amaç için kullanılması gerektiğine ve asla değişken isimleri ile kullanılmaması gerektiğine dikkate edin.
Kullanımdaki veritabanı tablolarının tüm alanları için belirtilen türleri herkes hatırlayamaz. Alanların türlerine bakmanız gerekirse, sözlükte görüntüleme ekranına erişmek için tablo adını çift tıklayın. Alanların türleri ile ilgili bilgiyi FIELDS sekmesinde görebilirsiniz. Daha sonra ABAP Editörüne dönmek için BACK düğmesini kullanın.
[post_ads_2]
Aşağıdaki program bir veritabanı tablosunun kayıtlarını satır satır listelemenin en basit yoludur:

SELECT * FROM zmember01 INTO wa_zmember01.
  WRITE / wa_zmember01.
ENDSELECT.

SELECT ifadesi kayıtların ZMEMBER01 tablosundan birer birer çalışma alanına (wa_zmember01) transferi anlamına gelir. Yıldız işareti (*), bir kaydın tüm alanlarının transfer edildiğini gösterir. Sadece bazı alanları aktarmak istiyorsanız, yıldız kullanmak yerine bu alanları belirtmeniz gerekir.

Bu yazım biçiminde, SELECT komutu döngü işlemine karşılık gelir. Veri tabanı tablosunun tüm kayıtları, program yapısına birer birer aktarılır. Döngü SELECT deyimi ile başlar ve ENDSELECT deyimi ile biter.

Listelerin Biçimlendirilmesi

Yapı okunan kayıtları işlemek için ifadeler içerir. Bu durumda, tüm WA_ZMEMBER01 yapısı, bir listeye kayıt kayıt yazılır. WRITE komutunda slash (/) ile yeni bir satırı tetikleyebilirsiniz. Slash'ten önce ve sonra bir boşluk eklemek gerektiğini unutmayın.

Veri tabanı tablosunda üç veri kaydı olduğundan, listede üç satır vardır: Listenin her bir satırı yapı ile aynı uzunluktadır. Çıktı listesi bir karakter dizesi olarak verilir. Alanlar arasında boş sütun yoktur. Listenin okunabilirliği optimal düzeyde değildir. Bu listede alanları istenen sırayla (aralarında biraz boşlukla) görmek daha iyi olurdu. Bu yapının alanlarını adreslemelisiniz. Aşağıdaki örneği inceleyin:

WRITE / wa_zmember01-mdob.

/ işareti alanın yeni bir satıra çıkışını tetikler. Ancak aşağıdaki açıklama, çıktıyı mevcut basılmış satırın sonuna yerleştirir; yani, alan yalnızca satıra ilave edilir.

WRITE wa_zmember01-mname.

Bu yaklaşım, sonsuz uzun satırlar üretebilir. Sistem kendi başına, ekranda bir satırı sadece ekran ayarları talep etmişse kırar. Kağıt üzerinde ise bir satırı, yazıcı çıktı ayarları veya kağıt genişliği talep etmişse kırar. Bu durumda, her geliştirici satırın doğru tasarlanmasından sorumludur.

Zincir İfade

Bir WRITE ifadesi yapının listede çıktı olarak istenen her bir alanı için gereklidir. Neyse ki, bir ifadenin her zaman yazılmasını önlemek için kolay bir yol vardır. Bu yol, birkaç WRITE ifadesinin birbiri ardına yürütüleceğini sisteme anlatır. 

İlk ifadeden sonra iki nokta üst üste yerleştirin (:), ve ifadeleri nokta yerine virgülle ayırın. Sadece son ifadeden sonra nokta koyun. Bizim örneğimizde zincir ifade aşağıdaki gibi oluşur:

WRITE: / wa_zmember01-mdob,
 wa_zmember01-mname.

Tabii ki, bu tür zincir ifadeler WRITE komutu ile sınırlı değildir.
  • [message]
    • İyi Görünüm
      • Kaynak kodunun şeffaflığını ve okunabilirliğini göz önünde bulundurun. Zincir ifadeler ile çalışırken bile, her bir ifadeyi yeni bir satıra yazma ilkesine uymalısınız. Tek satırda iki veya daha fazla ifadeyi yazmaktan mümkün olduğunca kaçının.

ULINE Komutu

Basit bir liste biçimlendirmesi için, (ek değişken olmaksızın) ULINE komutu listesinin yeni bir satırında yatay bir çizgi oluşturur:

ULINE.

Bir listenin bölümlerini ayırmak ve okunabilirliği artırmak için bu komutu kullanabilirsiniz.

SKIP Komutu

SKIP ifadesi listede boş satırlar oluşturur:

SKIP.

Birkaç tane boş satır oluşturmak istiyorsanız, sadece boş satır sayısını belirtin. Aşağıdaki ifade üç tane boş satır üretir:

SKIP 3.

YORUM

BLOGGER: 2
  1. ÇALIŞMA ALANI İÇİN wa_zmember01 İFADESİ BİR DEĞİŞKEN Mİ, EĞER DEĞİŞKEN İSE ÖNCEDEN ATAMAK GEREKMEZ Mİ?
    BEN ÇALIŞTIRAMADIM, "WA_ZMEMBER01" YERİNE BAŞKA BİR İFADE KULLANDIM UNKNOWN ŞEKLİNDE HATA VERİYOR.

    YanıtlaSil
  2. Örnek kod için bir sonraki yayını inceleyiniz https://www.sapmuhasebe.com/2017/08/abap-kodunun-yazlmas-ve-duzenlenmesi.html

    YanıtlaSil

Ad

/N/SAPTR/KDVB,1,AB03,1,AB08,1,ABAP,24,ABAVN,1,AFAB,1,AR02,1,AR03,1,AS01,1,AS02,2,AS03,1,AS11,1,AW01N,1,CO Kullanıcı,1,CO Uyarlama,1,CONCATENATE,1,CONDENSE,1,e-book,3,EC01,1,Excel,3,F-02,7,F-22,1,F-32,1,F-43,1,F-44,1,F-90,1,F-92,1,F110,2,FAGLL03,1,FB01,1,FB02,1,FB03,2,FB08,2,FB50,1,FB60,3,FB70,2,FBCJ,8,FBCJ3,1,FBCJC0,1,FBCJC1,1,FBCJC2,1,FBKP,1,FBL1N,3,FBL3N,1,FBL5N,4,FBN1,1,FBRA,2,FBV0,2,FBV2,1,FBV3,1,FBZP,1,FD01,1,FD08,1,FD09,1,FGI3,1,FI Kullanıcı,73,FI Uyarlama,41,FI01,1,FICO,1,FIT_DUE_DATE_SEL,1,FK01,1,FK02,1,FK08,1,FK09,1,FK10N,1,FS00,2,FS10N,1,FTXP,1,Gallery,4,LSMW,1,MIRO,2,Muhasebe,1,Nasıl,10,OB05,1,OB13,2,OB16,1,OB22,1,OB29,2,OB37,1,OB40,1,OB41,1,OB45,1,OB52,2,OB53,1,OB62,1,OB96,1,OBA0,1,OBA3,1,OBA4,1,OBA7,2,OBAR,1,OBAS,2,OBB8,1,OBB9,1,OBBO,1,OBBP,1,OBBU,1,OBC4,2,OBC5,1,OBCL,1,OBD2,1,OBD3,1,OBD4,1,OBWS,1,OBWW,1,OBXR,1,OBXT,1,OBXY,1,OBY6,1,OBYM,1,OBYN,1,OBYR,1,OKB2,1,OKB3,1,OLMRLIST,1,OX03,1,OX15,1,PFCG,1,REPLACE,1,S_ALR_87010175,1,S_ALR_87011965,1,S_ALR_87011990,1,S_ALR_87012004,1,S_ALR_87012050,1,S_ALR_87012052,1,S_ALR_87012082,1,S_ALR_87012090,1,S_ALR_87012172,1,S_ALR_87012183,1,S_ALR_87012357,1,SAP,3,SE11,5,SE38,6,SE71,1,SHCD,1,SHIFT,1,SKIP,1,SM30,1,SM35,1,SPLIT,1,Stopaj,3,ULINE,1,VN01,1,VOFA,1,WRITE,1,XD01,1,XDN1,1,XKN1,1,
ltr
item
SAP Muhasebe: Veri Tabanı Tablolarını Okuma ve Görüntüleme (WRITE, ULINE, SKIP Komutları)
Veri Tabanı Tablolarını Okuma ve Görüntüleme (WRITE, ULINE, SKIP Komutları)
https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhVVe4O10jF3Ad6S5PAf5PZQf9RbuUMAHysLl_ZDVl4kjj6dbqDYIiqsaeyposEHbFWWm2eoDETutiknuOMsw2dYyHsXDgDGrDD2D2KugC9-P4PtEJIZ2gF_cbW8yFrlyg3EgvfYLupGwc/s1600/Depositphotos_8855606_m-2015.jpg
https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhVVe4O10jF3Ad6S5PAf5PZQf9RbuUMAHysLl_ZDVl4kjj6dbqDYIiqsaeyposEHbFWWm2eoDETutiknuOMsw2dYyHsXDgDGrDD2D2KugC9-P4PtEJIZ2gF_cbW8yFrlyg3EgvfYLupGwc/s72-c/Depositphotos_8855606_m-2015.jpg
SAP Muhasebe
https://www.sapmuhasebe.com/2017/08/veri-taban-tablolarn-okuma-ve.html
https://www.sapmuhasebe.com/
https://www.sapmuhasebe.com/
https://www.sapmuhasebe.com/2017/08/veri-taban-tablolarn-okuma-ve.html
true
2532429962024234885
UTF-8
Loaded All Posts Not found any posts TÜMÜNÜ GÖSTER Devamı Yanıtla Cancel reply Sil By Ana Sayfa SAYFALAR KAYITLAR Tümünü Göster BENZER YAYINLAR ETİKET ARŞİV SEARCH TÜM KAYITLAR İsteğinize Uygun Kayıt Bulunamadı Ana Sayfaya Dön Pazar Pazartesi Salı Çarşamba Perşembe Cuma Cumartesi Paz Pzt Sal Çrş Prş Cum Cmt Ocak Şubat Mart Nisan Mayıs Haziran Temmuz Ağustos Eylül Ekim Kasım Aralık Oca Şub Mar Nis Mayıs Haz Tem Ağu Eyl Eki Kas Ara az önce 1 dakika önce $$1$$ minutes ago 1 saat önce $$1$$ hours ago Dün $$1$$ days ago $$1$$ weeks ago 5 haftadan fazla Takipçiler Takip Et THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy Table of Content