adesso orange🍊Stellenangebote:
Software Engineer Trainee · Senior | (Senior) Cloud Software Engineer BTP
(Senior) Consultant Technologie · Consultant ABAP
Werkstudent Softwareentwicklung · Fiori / UI5 · Consulting · Application Management

Ich habe manuell über mehrere Versionen das Wiki geupdated. Evtl. läuft es noch nicht ganz rund ツ

CDS Views Grundlagen: Unterschied zwischen den Versionen

Aus SAP Wiki ツ
M1ch3lde (Diskussion | Beiträge)
M1ch3lde (Diskussion | Beiträge)
K M1ch3lde verschob die Seite CDS Views nach CDS Views Grundlagen
 
(20 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
[[Kategorie:Core Data Services]]
[[Kategorie:Core Data Services]]
== Annotiations ==
= Definierung von Eingeschaften, Einstellungen und Metadaten für den View.
{| class="wikitable"
|-
|@AbapCatalog.sqlViewName
|Name für automatisch generierter View in der SE11
|-
|@AbapCatalog.compiler.compareFilter
|True:<br />False:
|-
|@AbapCatalog.preserveKey
|True:<br />False:
|-
|@AccessControl.authorizationCheck
|<nowiki>#NOT_REQUIRED:</nowiki>
<nowiki>#CHECK:</nowiki><br />
<nowiki>#NOT_ALLOWED:</nowiki><br />
<nowiki>#PRIVILEGED_ONLY:</nowiki>
|-
|@EndUserText.label
|Beschreibungstext des Views
|-
|@VDM.viewType
|#CONSUMPTION
|}


== Associations ==
== Associations ==


*Datenbankseitig entsprechen Associations den Joins
* Standardgemäß Abbildung als LEFT OUTER JOIN
*Standardgemäß LEFT OUTER JOIN
*  
** kann übersteuert werden z.B. mit INNER


<syntaxhighlight lang="abap" line start="1">
<syntaxhighlight lang="php" copy>
@AbapCatalog.sqlViewName: 'ZCDSUSERINFOVIEW'
@AbapCatalog.compiler.compareFilter: true
@AbapCatalog.preserveKey: true
@AccessControl.authorizationCheck: #NOT_REQUIRED
@EndUserText.label: 'Userinformationen'
@VDM.viewType: #CONSUMPTION
define view ZCDS_USER_INFORMATION as select from usr21 as user
define view ZCDS_USER_INFORMATION as select from usr21 as user
-- JOIN
-- JOIN
Zeile 30: Zeile 50:
     name.name_first as Vorname,
     name.name_first as Vorname,
     name.name_last as Nachname,
     name.name_last as Nachname,
     email[inner].smtp_addr as EMail, // ohne inner = outer join über 600 Einträge, mit Inner nur Einträge wo die E-Mail vorhanden ist
     email[inner].smtp_addr as EMail, // ohne inner = outer join mehr Einträge, mit Inner nur Einträge wo die E-Mail vorhanden ist
     company.name1 as Firmenname
     company.name1 as Firmenname
}
}
Zeile 36: Zeile 56:


== Sonstiges ==
== Sonstiges ==
=== Kommentare ===
* //
* --


=== SY-Felder ===
=== SY-Felder ===

Aktuelle Version vom 23. November 2024, 19:39 Uhr


Annotiations

= Definierung von Eingeschaften, Einstellungen und Metadaten für den View.

@AbapCatalog.sqlViewName Name für automatisch generierter View in der SE11
@AbapCatalog.compiler.compareFilter True:
False:
@AbapCatalog.preserveKey True:
False:
@AccessControl.authorizationCheck #NOT_REQUIRED:

#CHECK:
#NOT_ALLOWED:
#PRIVILEGED_ONLY:

@EndUserText.label Beschreibungstext des Views
@VDM.viewType #CONSUMPTION

Associations

  • Standardgemäß Abbildung als LEFT OUTER JOIN
define view ZCDS_USER_INFORMATION as select from usr21 as user
-- JOIN
//left outer join adrc as company
//    on user.addrnumber = company.addrnumber
//left outer join adr6 as email
//    on user.addrnumber = email.addrnumber and user.persnumber = email.persnumber
//left outer join adrp as name
//    on user.persnumber = name.persnumber
-- ASSOCIATIONS
association to adrc as company on user.addrnumber = company.addrnumber
association to adr6 as email on user.addrnumber = email.addrnumber and user.persnumber = email.persnumber
association to adrp as name on user.persnumber = name.persnumber
{
    user.bname as Benutzername,
    name.name_first as Vorname,
    name.name_last as Nachname,
    email[inner].smtp_addr as EMail, // ohne inner = outer join mehr Einträge, mit Inner nur Einträge wo die E-Mail vorhanden ist
    company.name1 as Firmenname
}

Sonstiges

Kommentare

  • //
  • --

SY-Felder

sy-mandt #CLIENT
sy-datum #SYSTEM_DATE
sy-uzeit #SYSTEM_TIME
sy-langu #SYSTEM_LANGUAGE
sy-user #USER