Escolar Documentos
Profissional Documentos
Cultura Documentos
Ha1000 Abap Programming On Sap Hana
Ha1000 Abap Programming On Sap Hana
com
A B A P P r o g r a m m in g
H o n AS A P 4 H 0 A N 0 A
S A P H A N A
D a t e
T r a i n i n g C e n t e r
I n s t r u c t o r s
E d u c a t i o n W e b s it e
P a r t i c i p a n t H a n d b o o k
C o u r s e V e r s io n : 9 8
C o u r s e D u r a t io n : 2 D a y ( s )
M a t e r ia l N u m b e r : 5 0 1 1 7 4 6 7
A n S A P c o u rs e - u s e it t o le a r n , r e f e r e n c e i t f o r w o r k
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 1/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o p y r i g h t
C o p y rig h t © 2 0 1 3 S A P A G . A l l r i g h t s r e s e r v e d .
N o p a r t o f t h i s p u b l i c a t i o n m a y b e r e p r o d u c e d o r t r a n s m i t t e d i n a n y f o r m o r f o r a n y p u r p o s e
w i t h o u t t h e e x p r e s s p e r m i s s i o n o f S A P A G . T h e i n f o r m a t i o n c o n t a i n e d h e r e i n m a y b e c h a n g e d
w i t h o u t p r i o r n o t i c e .
S o m e s o f tw a re p r o d u c ts m a rk e te d b y S A P A G a n d i t s d i s t r i b u t o r s c o n t a i n p r o p r i e t a r y s o f t w a r e
c o m p o n e n t s o f o t h e r s o f t w a r e v e n d o r s .
T r a d e m a r k s
• M ic ro s o ft® , W IN D O W S ® , N T ® , E X C E L ® , W o rd ® , P o w e rP o in t® a n d S Q L S e rv e r® a r e
r e g i s t e r e d t r a d e m a r k s o f M i c r o s o f t C o r p o r a t i o n .
• I B M ® , D B 2 ® , O S / 2 ® , D B 2 /6 0 0 0 ® , P a r a l l e l S y s p le x ® , M V S / E S A ® , R S / 6 0 0 0 ® , A I X ® ,
S / 3 9 0 ® , A S / 4 0 0 ® , O S / 3 9 0 ® , a n d O S / 4 0 0 ® a r e r e g i s t e r e d t r a d e m a r k s o f I B M C o r p o r a t i o n .
• O R A C L E ® i s a r e g is t e r e d t r a d e m a r k o f O R A C L E C o r p o r a t i o n .
• IN F O R M IX ® -O n L in e fo r S A P a n d IN F O R M IX ® D y n a m ic S e rv e rT M a r e r e g i s t e r e d
t r a d e m a r k s o f I n f o r m i x S o f t w a r e I n c o r p o r a t e d .
• U N I X ® , X /O p e n ® , O S F /1 ® , a n d M o tif ® a r e r e g is t e r e d t r a d e m a r k s o f t h e O p e n G r o u p .
• C i t r i x ® , t h e C i t r i x l o g o , I C A ® , P r o g r a m N e i g h b o r h o o d ® , M e t a F r a m e ® , W i n F r a m e ® ,
V i d e o F r a m e ® , M u l t i W i n ® a n d o t h e r C i t r i x p r o d u c t n a m e s r e f e r e n c e d h e r e i n a r e t r a d e m a r k s
o f C i t r i x S y s t e m s , I n c .
• H T M L , D H T M L , X M L , X H T M L a r e t r a d e m a r k s o r r e g is t e r e d t r a d e m a r k s o f W 3 C ® , W o r l d
W i d e W e b C o n s o r t i u m , M a s s a c h u s e t t s I n s t i t u t e o f T e c h n o l o g y .
• J A V A ® i s a r e g i s t e r e d t r a d e m a r k o f S u n M i c r o s y s t e m s , I n c .
• J A V A S C R I P T ® i s a r e g i s t e r e d t r a d e m a r k o f S u n M i c r o s y s t e m s , I n c . , u s e d u n d e r l i c e n s e f o r
t e c h n o l o g y i n v e n t e d a n d i m p l e m e n t e d b y N e t s c a p e .
• S A P , S A P L o g o , R /2 , R IV A , R /3 , S A P A rc h iv e L i n k , S A P B u sin e s s W o rk o w , W e b F lo w , S A P
E a rly W a tc h , B A P I, S A P P H IR E , M a n a g e m e n t C o c k p it, m y S A P .c o m L o g o a n d m y S A P .c o m
a re tr a d e m a rk s o r r e g is te re d tr a d e m a rk s o f S A P A G in G e rm a n y a n d in s e v e ra l o th e r c o u n t r i e s
a ll o v e r th e w o r ld . A ll o th e r p ro d u c ts m e n tio n e d a re tra d e m a rk s o r r e g i s te r e d tra d e m a rk s o f
th e ir re s p e c t i v e c o m p a n i e s .
D i s c l a i m e r
g 2 0 1 3 2 1 4 5 3 8 3 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 2/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
A b o u t T h i s H a n d b o o k
T h i s h a n d b o o k i s i n t e n d e d t o c o m p l e m e n t t h e i n s t r u c t o r - l e d p r e s e n t a t i o n o f t h i s
c o u r s e , a n d s e r v e a s a s o u r c e o f r e f e r e n c e . I t i s n o t s u i t a b l e f o r s e l f - s t u d y .
T y p o g r a p h i c C o n v e n t i o n s
A m e r i c a n E n g l i s h i s t h e s t a n d a r d u s e d i n t h i s h a n d b o o k . T h e f o l l o w i n g
t y p o g r a p h i c c o n v e n t i o n s a r e a l s o u s e d .
T y p e S ty le D e s c r ip tio n
E x a m p l e t e x t W o r d s o r c h a r a c t e r s t h a t a p p e a r o n t h e s c r e e n . T h e s e
i n c l u d e e l d n a m e s , s c r e e n t i t l e s , p u s h b u t t o n s a s w e l l
a s m e n u n a m e s , p a t h s , a n d o p t i o n s .
A l s o u s e d f o r c r o s s - r e f e r e n c e s t o o t h e r d o c u m e n t a t i o n
b o t h i n t e r n a l a n d e x t e r n a l .
E x a m p l e t e x t E m p h a s i z e d w o r d s o r p h r a s e s i n b o d y t e x t , t i t l e s o f
g r a p h i c s , a n d t a b l e s
E X A M P L E T E X T N a m e s o f e l e m e n t s i n t h e s y s t e m . T h e s e i n c l u d e
r e p o r t n a m e s , p r o g r a m n a m e s , t r a n s a c t i o n c o d e s , t a b l e
n a m e s , a n d i n d i v i d u a l k e y w o r d s o f a p r o g r a m m i n g
l a n g u a g e , w h e n s u r r o u n d e d b y b o d y t e x t , f o r e x a m p l e
S E L E C T a n d I N C L U D E .
E x a m p l e t e x t S c re e n o u t p u t . T h i s i n c l u d e s l e a n d d i r e c t o r y n a m e s
a n d t h e i r p a t h s , m e s s a g e s , n a m e s o f v a r i a b l e s a n d
p a ra m e t e r s , a n d p a s s a g e s o f t h e s o u r c e t e x t o f a
p ro g r a m .
E x a m p l e t e x t E x a c t u s e r e n t r y . T h e s e a r e w o r d s a n d c h a r a c t e r s t h a t
y o u e n t e r i n t h e s y s t e m e x a c t l y a s t h e y a p p e a r i n t h e
d o c u m e n t a t i o n .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . i i i
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 3/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
A b o u t T h is H a n d b o o k H A 4 0 0
I c o n s i n B o d y T e x t
T h e f o l l o w i n g i c o n s a r e u s e d i n t h i s h a n d b o o k .
I c o n M e a n in g
F o r m o r e i n f o r m a t i o n , t i p s , o r b a c k g r o u n d
N o t e o r f u r t h e r e x p l a n a t i o n o f p r e v i o u s p o i n t
E x c e p t i o n o r c a u t i o n
P r o c e d u r e s
In d ic a te s th a t th e ite m i s d i s p l a y e d i n t h e i n s t r u c t o r ’ s
p r e s e n t a t i o n .
i v © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 4/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o n t e n t s
C o u r s e O v e r v i e w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . v i i
C o u r s e G o a l s . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . v i i
C o u r s e O b j e c t i v e s . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . v i i
U n i t 1 : I n t r o d u c t i o n a n d T e c h n i c a l C o n c e p t s . . . . . . . . . . . . . . . . . . . . . . . 1
I n t r o d u c t i o n . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
H A N A T e c h n i c a l C o n c e p t s . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
I n t r o d u c t i o n t o H A N A S t u d i o . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 0
U n it 2 : T a k in g A B A P to H A N A . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 9
O p tim iz e C o n v e n tio n a l C o d e . .. . .. .. .. . ... .. .. . .. . .. .. . . .. .. ... .. . . . 2 1
A c c e s s t h e S A P H A N A D a ta b a s e U s in g O p e n S Q L a n d
S e c o n d a r y C o n n e c tio n . .. .. .. .. .. .. .. .. .. .. .. . . .. .. .. .. .. .. .. . . . . 5 2
T a b le s in S A P H A N A S tu d io . .... .... .. ........ ... ..... .. .. .. ..... . . . 5 6
P e r f o r m a n c e R u le s a n d G u id e lin e s fo r S A P H A N A .. .. .. ..... . . . 7 0
U n i t 3 : I m p l e m e n t i n g A B A P R e p o r t o n H A N A U s in g A D B C . . . 7 5
W h y a r e w e u s i n g n a t i v e S Q L ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 6
A B A P D a t a b a s e C o n n e c t i v i t y ( A D B C ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 9
N a t i v e S Q L S y n t a x . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 3
U n i t 4 : C o n s u m i n g H A N A V i e w s a n d P r o c e d u r e s in A B A P . . . 1 1 3
W o r k i n g w i t h V i e w s in S A P H A N A S tu d io ... .. .. .. . . . . . . . . . . . . . . . 1 1 4
O v e r v i e w o f D i f f e re n t T y p e s o f S A P H A N A V ie w s . . . . . . . . . . . . . . . 1 1 9
C o n s u m in g S A P H A N A V ie w s in A B A P .. ... .. .. .. . . . . . . . . . . . . . . . 1 2 3
C a l l i n g S A P H A N A P ro c e d u re s in A B A P . ... .. .. .. . . . . . . . . . . . . . . . 1 4 6
U n i t 5 : C r e a t i n g A n a l y t i c a l V i e w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 6 1
C r e a t i n g A n a l y t i c V i e w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 6 2
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . v
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 5/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o n te n ts H A 4 0 0
v i © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 6/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o u r s e O v e r v ie w
T a r g e t A u d i e n c e
T h i s c o u r s e i s i n t e n d e d f o r t h e f o l l o w i n g a u d i e n c e s :
• P r i m a r y t a r g e t a u d i e n c e s f o r t h i s t r a i n i n g a r e d e v e l o p e r s a n d d e v e l o p m e n t
c o n s u l t a n t s b u t a l s o o t h e r r o l e s i n v o l v e d w i t h i m p l e m e n t i n g o r r e v i e w i n g
p r o g r a m c o d e t o o p t i m i z e A B A P b a s e d a p p l i c a t i o n s f o r S A P H A N A .
C o u r s e P r e r e q u i s i t e s
R e q u ir e d K n o w l e d g e
• H A 1 0 0 H A N A o v e r v ie w
• B C 4 0 0 A B A P W o r k b e n c h
• B C 4 0 1 A B A P O b je c t s
• B C 4 0 2 A d v a n c e d A B A P
• E x p e r i e n c e A B A P P r o g r a m i n g ( p r o c e d u r e + o b je c t o r i e n t e d )
• O p e n S Q L ( jo i n s , v i e w , a g g r e g a t i o n s )
R e c o m m e n d e d K n o w le d g e
• H A 1 5 0 S Q L B a s ic s f o r S A P H A N A
C o u r s e G o a ls
T h i s c o u r s e w i l l p r e p a r e y o u t o :
• D e v e l o p a n d o p t i m i z e A B A P a p p l i c a t i o n s t h a t a c c e s s d a t a s t o r e d i n t h e S A P
H A N A D a t a b a s e .
C o u r s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s c o u r s e , y o u w i l l b e a b l e t o :
• U n d e rs ta n d th e T e c h n ic a l S A P H A N A c o n c e p ts
• U n d e r s ta n d O p tim iz a tio n o f c la s s ic a l A B A P in H A N A C o n t e x t
• D e s c r i b e t h e u s a g e o f A n a l y s i s T o o l s ( R u n t i m e A n a l y s i s , C o d e I n s p e c t o r ,
S Q L T r a c e )
• U n d e r s t a n d S Q L P e r f o r m a n c e R u l e s o f A B A P f o r H A N A
• E x p la in Im p le m e n tin g A B A P re p o rt o n H A N A u s i n g A D B C ( A B A P D a t a
B a s e C o n n e c t i v i t y )
• E x p la in C o n s u m in g H A N A v i e w s i n A B A P
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . v i i
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 7/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o u r s e O v e r v ie w H A 4 0 0
• E x p la in C re a tin g H A N A v i e w s a n d C o n s u m i n g i n A B A P
v i i i © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 8/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
I n t r o d u c t i o n a n d T e c h n i c a l C o n c e p t s
U n i t 1
U n i t O v e r v i e w
T h i s U n i t i s d e s i g n e d t o t e a c h t h e f o l l o w i n g t o p i c s :
• I n t r o d u c t i o n
• H A N A T e c h n i c a l c o n c e p t s
• I n tr o d u c tio n to H A N A S t u d i o
U n i t O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s u n i t , y o u w i l l b e a b l e t o :
• D e sc rib e th e H A N A e v o l u t i o n , a r c h i t e c t u r e , a n d d i r e c t i o n
• U n d e r s t a n d t h e f u n d a m e n t a l t e c h n ic a l c o n c e p t s o f S A P H A N A
• E x p la in t h e c e n tr a l f u n c ti o n s o f H A N A S t u d io
• C h o o s e d i f f e r e n t p e r s p e c t i v e s
• S e t u p a c o n n e c tio n to a S A P H A N A D a t a b a s e
U n i t C o n t e n t s
L e s s o n : In tr o d u c tio n ....... .. ........ ..... .. .. .... .... ... ... ... .... .... .. .. .... .. . . 2
L e s s o n : H A N A T e c h n ic a l C o n c e p ts . ... .. .. . ... .. .. . .. ... ... .. .. . ... .. .. . ... .. . . 6
L e s s o n : In tro d u c tio n to H A N A S tu d io . . .. .. . .. . .. .. . .. ... ... .. .. . ... .. .. . ... .. 1 0
E x e r c is e 1 : L o g o n to S y s te m s a n d C re a te P a c k a g e s ... .... .. .. .... .. 1 5
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 9/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
L e s s o n : I n t r o d u c t i o n
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• D e sc rib e th e H A N A e v o l u t i o n , a r c h i t e c t u r e , a n d d i r e c t i o n
B u s i n e s s E x a m p l e
F i g u r e 1 : T e c h n o l o g y I n n o v a t i o n s
F ig u r e 2 : H A N A E v o l u t i o n
2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 10/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : In tr o d u c tio n
F ig u re 3 : H A N A A r c h i t e c t u r e
• N e t W e a v e r 6 4 B I T i s m a n d a t o r y
• N e t W e a v e r d u a l s t a c k i s n o t s u p p o r t e d a n y m o r e
F ig u re 4 : H A N A D i r e c t i o n
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 11/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
F i g u r e 5 : A v o i d B o t t l e n e c k s
F ig u r e 6 : S A P H A N A : A B A P D e v e lo p e r s Q u e s ti o n s
4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 12/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : In tr o d u c tio n
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• D e s c r i b e t h e H A N A e v o l u t i o n , a r c h i t e c t u r e , a n d d i r e c t i o n
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 13/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
L e s s o n : H A N A T e c h n i c a l C o n c e p t s
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• U n d e r s t a n d t h e f u n d a m e n t a l t e c h n ic a l c o n c e p t s o f S A P H A N A
B u s i n e s s E x a m p l e
F ig u r e 7 : S A P H A N A F a c t s
F ig u r e 8 : C o lu m n a n d R o w S t o r e
6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 14/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : H A N A T e c h n ic a l C o n c e p ts
F ig u r e 9 : R o w S t o r e
F i g u r e 1 0 : C o l u m n S t o r e
B y a c c e s s in g d a ta in c o lu m n - s to r e o r d e r, y o u b e n e t im m e n s e ly f r o m s i m p l i e d
t a b l e - s c a n a n d d a t a p r e - c a c h i n g .
T h i s c a n m a k e a l l t h e d i f f e r e n c e i n p e r f o r m a n c e .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 15/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
F ig u r e 1 1 : C o lu m n a n d R o w S t o r e
F i g u r e 1 2 : E x a m p l e : C o m p r e s s io n o f C o l u m n
P r e x e n c o d i n g , s p a r s e e n c o d i n g , d e l t a e n c o d i n g
• E f c i e n t c o m p r e s s i o n m e t h o d s ( r u n l e n g t h , b i t v e c t o r , d i c t i o n a r y , e t c . )
• C o m p r e s s i o n w o r k s w e l l w i t h c o l u m n s a n d c a n s p e e d u p o p e r a t i o n s o n
c o l u m n s
• B e c a u s e o f c o m p r e s s i o n , w r i t e c h a n g e s i n t o l e s s c o m p r e s s e d d e l t a s t o r a g e
( u s e s a l s o a d i c t i o n a r y )
• N e e d s to b e m e r g e d in to c o lu m n s f r o m t i m e t o t i m e o r w h e n a c e r t a i n s i z e
i s e x c e e d e d
• D e l t a m e r g e c a n b e d o n e a s y n c h r o n o u s l y
• T r a d e - o f f b e t w e e n c o m p r e s s i o n r a t i o a n d d e l t a m e r g e r u n t i m e
8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 16/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : H A N A T e c h n ic a l C o n c e p ts
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• U n d e r s t a n d t h e f u n d a m e n t a l t e c h n ic a l c o n c e p t s o f S A P H A N A
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 17/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
L e s s o n : In t r o d u c tio n to H A N A S t u d i o
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• E x p la in th e c e n tr a l f u n c tio n s o f H A N A S t u d io
• C h o o s e d i f f e r e n t p e r s p e c t i v e s
• S e t u p a c o n n e c tio n to a S A P H A N A D a t a b a s e
B u s i n e s s E x a m p l e
F i g u r e 1 3 : C e n t r a l F a c t s
1 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 18/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : In tr o d u c tio n to H A N A S tu d io
F i g u r e 1 4 : P e r s p e c t i v e s
• W h e n c r e a t i n g v i e w s y o u w a n t t o u s e t h e M o d e l e r p e r s p e c t i v e .
F ig u r e 1 5 : G e ttin g S t a r t e d – T h e M o d e l e r P e r s p e c t i v e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 19/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
F i g u r e 1 6 : T h e M o d e l e r P e r s p e c t i v e
F i g u r e 1 7 : S y s t e m
1 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 20/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : In tr o d u c tio n to H A N A S tu d io
F ig u r e 1 8 : C r e a tin g C o n t e n t P a c k a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 21/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
1 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 22/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : In tr o d u c tio n to H A N A S tu d io
E x e r c i s e 1 : L o g o n t o S y s t e m s a n d C r e a t e
P a c k a g e s
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• l o g o n t o S A P N e t W e a v e r A p p li c a t i o n S e r v e r A B A P
• o p e n S A P H A N A S tu d io a n d c o n n e c t to th e S A P H A N A S e r v e r
• c r e a t e a d e v e l o p m e n t p a c k a g e i n S A P N e t W e a v e r A S A B A P
• c r e a t e a c o n t e n t p a c k a g e i n S A P H A N A
B u s i n e s s E x a m p l e
T a s k 1 : L o g o n t o A p p l i c a t i o n S e r v e r A B A P
L o g o n t o t h e S A P N e t W e a v e r A p p li c a t i o n S e r v e r A B A P w i t h t h e u s e r a n d
p a s s w o r d p r o v i d e d b y y o u r i n s t r u c t o r . O p e n t h e A B A P W o r k b e n c h ( S E 8 0 ) a n d
c r e a t e d e v e l o p m e n t p a c k a g e Z H A 4 0 0 _ # # , w h e r e # # s t a n d s f o r y o u r g r o u p I D .
1 . S t a r t S A P l o g o n a n d l o g o n t o t h e s y s t e m .
2 . S t a r t t r a n s a c t i o n S E 8 0 a n d c r e a t e t h e p a c k a g e . A s s i g n t h e p a c k a g e t o
a p p l i c a t i o n c o m p o n e n t “ C A ” a n d s o f t w a r e c o m p o n e n t “ H O M E ” . U s e t h e
w o r k b e n c h r e q u e s t a l r e a d y c r e a t e d b y y o u r i n s t r u c t o r ( p r e s s b u t t o n O w n
R e q u e s t s t o n d a n d u s e t h i s r e q u e s t ) .
T a s k 2 : L o g o n to S A P H A N A
O p e n S A P H A N A S t u d i o a n d e s t a b l i s h a c o n n e c t i o n t o t h e S A P H A N A S e r v e r
t o l d t o y o u b y y o u r i n s t r u c t o r . U s e t h e u s e r I D a n d p a s s w o r d p r o v i d e d b y y o u r
i n s t r u c t o r . C r e a t e c o n t e n t p a c k a g e z h a 4 0 0 _ # # , w h e r e # # s t a n d s f o r y o u r g r o u p I D .
1 . O p e n S A P H A N A S tu d io .
2 . A d d a n e w s y ste m . U s e th e s e rv e r I D , u se r I D a n d P a s s w o r d p r o v i d e d b y
y o u r i n s t r u c t o r .
3 . C r e a t e t h e c o n t e n t p a c k a g e .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 23/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 1 : In tr o d u c tio n a n d T e c h n ic a l C o n c e p ts H A 4 0 0
S o l u t io n 1 : L o g o n t o S y s t e m s a n d C r e a t e
P a c k a g e s
T a s k 1 : L o g o n t o A p p l i c a t i o n S e r v e r A B A P
L o g o n t o t h e S A P N e t W e a v e r A p p li c a t i o n S e r v e r A B A P w i t h t h e u s e r a n d
p a s s w o r d p r o v i d e d b y y o u r i n s t r u c t o r . O p e n t h e A B A P W o r k b e n c h ( S E 8 0 ) a n d
c r e a t e d e v e l o p m e n t p a c k a g e Z H A 4 0 0 _ # # , w h e r e # # s t a n d s f o r y o u r g r o u p I D .
1 . S t a r t S A P l o g o n a n d l o g o n t o t h e s y s t e m .
a ) P e rfo rm t h i s s t e p a s y o u h a v e ( h o p e f u l l y ) d o n e b e f o r e .
2 . S ta rt t ra n s a c tio n S E 8 0 a n d c re a te t h e p a c k a g e . A s s i g n t h e p a c k a g e t o
a p p lic a tio n c o m p o n e n t “ C A ” a n d s o f t w a r e c o m p o n e n t “ H O M E ” . U s e t h e
w o rk b e n c h re q u e st a lre a d y c re a te d b y y o u r i n s t r u c t o r ( p r e s s b u t t o n O w n
R e q u e s t s t o n d a n d u s e th is re q u e s t ) .
a ) P e rfo rm t h i s s t e p a s y o u h a v e ( h o p e f u l l y ) d o n e b e f o r e .
T a s k 2 : L o g o n to S A P H A N A
O p e n S A P H A N A S t u d i o a n d e s t a b l i s h a c o n n e c t i o n t o t h e S A P H A N A S e r v e r
t o l d t o y o u b y y o u r i n s t r u c t o r . U s e t h e u s e r I D a n d p a s s w o r d p r o v i d e d b y y o u r
i n s t r u c t o r . C r e a t e c o n t e n t p a c k a g e z h a 4 0 0 _ # # , w h e r e # # s t a n d s f o r y o u r g r o u p I D .
1 . O p e n S A P H A N A S tu d io .
a ) C h o o s e h d b s t u d i o f r o m t h e W i n d o w s S t a r t M e n u
2 . A d d a n e w s y ste m . U s e th e s e rv e r I D , u s e r I D a n d P a s s w o r d p r o v i d e d b y
y o u r i n s t r u c t o r .
a ) M a k e s u r e y o u a r e i n t h e M o d e l e r p e r s p e c t i v e . I f n o t , c h a n g e
p e r s p e c t i v e u s i n g t h e p u s h b u t t o n s i n t h e u p p e r r i g h t - h a n d c o r n e r .
b ) R i g h t - c l i c k a n y w h e r e I n t h e N a v i g a t o r w i n d o w o n t h e l e f t , a n d c h o o s e
A d d S y s t e m . . . .
c ) E n t e r h o s t n a m e a n d i n s t a n c e n u m b e r p r o v i d e d b y y o u r i n s t r u c t o r a n d a
d e s c r i p t i o n , t h e n p r e s s b u t t o n N e x t > .
d ) E n te r u s e r I D a n d p a s s w o r d p r o v i d e d b y y o u r i n s t r u c t o r , t h e n c h o o s e
F i n i s h .
3 . C r e a t e t h e c o n t e n t p a c k a g e .
a ) I n t h e N a v i g a t o r w i n d o w , o p e n n o d e C o n t e n t . R i g h t c l i c k o n t h i s n o d e
a n d c h o o s e N e w - > P a c k a g e . . . .
b ) E n t e r t h e p a c k a g e n a m e a n d a d e s c r i p t i o n , t h e n p r e s s b u t t o n O K
.
1 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 24/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : In tr o d u c tio n to H A N A S tu d io
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• E x p la in t h e c e n tr a l f u n c ti o n s o f H A N A S t u d io
• C h o o s e d i f f e r e n t p e r s p e c t i v e s
• S e t u p a c o n n e c tio n to a S A P H A N A D a t a b a s e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 25/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it S u m m a r y H A 4 0 0
U n it S u m m a r y
Y o u s h o u ld n o w b e a b l e t o :
• D e sc rib e th e H A N A e v o l u t i o n , a r c h i t e c t u r e , a n d d i r e c t i o n
• U n d e r s t a n d t h e f u n d a m e n t a l t e c h n ic a l c o n c e p t s o f S A P H A N A
• E x p la in th e c e n tr a l f u n c tio n s o f H A N A S t u d io
• C h o o s e d i f f e r e n t p e r s p e c t i v e s
• S e t u p a c o n n e c tio n to a S A P H A N A D a t a b a s e
1 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 26/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 27/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 28/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n i t 2
T a k in g A B A P t o H A N A
U n i t O v e r v i e w
T h i s U n i t i s d e s i g n e d t o t e a c h t h e f o l l o w i n g t o p i c s :
• O p ti m i z e c o n v e n ti o n a l c o d e
• A c c e s s t h e S A P H A N A D a t a b a s e u s i n g O p e n S Q L a n d s e c o n d a r y c o n n e c t i o n
• T a b le s in S A P H A N A S tu d io
• P e r f o r m a n c e r u l e s a n d g u i d e l i n e s f o r S A P H A N A
U n i t O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s u n i t , y o u w i l l b e a b l e t o :
• U n d e r s t a n d t h e R u n t i m e A n a l y s i s ( S E 3 0 )
• U n d e r s t a n d t h e A B A P T r a c e ( S A T )
• U n d e r s t a n d t h e C o d e I n s p e c t o r ( S C I )
• U n d e r s t a n d t h e S Q L T r a c e ( S T 0 5 )
• D e s c rib e h o w to a c c e s s th e S A P H A N A D a t a b a s e b y u s i n g O p e n S Q L a n d a
s e c o n d a r y d a t a b a s e c o n n e c t i o n
• U n d e rs ta n d S c h e m a ta a n d T a b le s in S A P H A N A S t u d i o
• A n a ly z e th e D e n itio n o f T a b le s in S A P H A N A S t u d i o
• U n d e r s t a n d t h e p e r f o r m a n c e r u l e s a n d g u i d e l i n e s f o r H A N A
U n i t C o n t e n t s
L e s s o n : O p tim iz e C o n v e n tio n a l C o d e . . . . . . . ... .. ... ... . . ... .. ... ... .. ... ... . . 2 1
E x e r c is e 2 : Im p ro v e O p e n S Q L S ta te m e n ts b y U s in g F i e l d L i s t s
in s te a d o f S E L E C T * . .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. .. . . .. .. .. .. .. .. .. .. .. .. . 2 3
E x e r c is e 3 : Im p ro v e O p e n S Q L S ta te m e n ts b y U s in g a J o in in s te a d o f
n e s te d S E L E C T -s ta te m e n ts . . .. . .. . .. .. . ... .. ... .. .. . ... .. ... ... .. ... ... . . 3 3
E x e r c is e 4 : Im p ro v e O p e n S Q L S ta te m e n ts b y b u ffe r in g a ll d a ta y o u
n e e d ..... .................................. ............. ..................... . 4 3
L e s s o n : A c c e s s th e S A P H A N A D a ta b a s e U s in g O p e n S Q L a n d
S e c o n d a ry C o n n e c tio n . . . . . . . . . . . . . . . . . . . . . . . .. .. .. .. .. .. . . .. .. .. .. .. .. .. .. .. .. . 5 2
L e s s o n : T a b le s in S A P H A N A S tu d io . . . . . . ............. ..................... . 5 6
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 29/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
E x e r c is e 5 : A c c e s s S A P H A N A v ia a s e c o n d a r y D a ta b a s e
C o n n e c t i o n . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 9
L e s s o n : P e r fo r m a n c e R u le s a n d G u id e lin e s fo r S A P H A N A . . . . . . . . . . . . . . . 7 0
2 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 30/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
L e s s o n : O p t i m i z e C o n v e n t i o n a l C o d e
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• U n d e r s t a n d t h e R u n t i m e A n a l y s i s ( S E 3 0 )
• U n d e r s t a n d t h e A B A P T r a c e ( S A T )
• U n d e r s t a n d t h e C o d e I n s p e c t o r ( S C I )
• U n d e r s t a n d t h e S Q L T r a c e ( S T 0 5 )
B u s i n e s s E x a m p l e
F i g u r e 1 9 : C la s s ic R u n t im e A n a ly s is ( S E 3 0 ) & A B A P T r a c e ( S A T )
F ig u r e 2 0 : A B A P T r a c e ( S A T )
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 31/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
F i g u r e 2 1 : C o d e I n s p e c t o r
F i g u r e 2 2 : S Q L T r a c e ( S T 0 5 )
2 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 32/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
E x e r c is e 2 : I m p r o v e O p e n S Q L S t a t e m e n t s
b y U s in g F i e ld L i s t s i n s t e a d o f S E L E C T *
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• a n a ly z e a p ro g ra m w i t h A B A P T r a c e ( S A T ) t o l o c a t e p e r f o r m a n c e l e a k s
• d e c r e a s e t h e r u n t i m e f o r d a t a b a s e s e l e c t s b y u s i n g e l d l i s t s i n s t e a d o f
S E L E C T *
• q u a n ti f y t h e i m p r o v e m e n t w i t h A B A P T r a c e ( S A T )
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 1
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 1
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 1 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ O S Q L _ 1 , w h e r e # # i s y o u r g r o u p
ne ux me c b u e t e r ) t . h A e n p a r lo y g z r e a m t h . e p r o g r a m c o d e t o g e t a n i d e a i t s f u n c t i o n a l i t y . A c t i v a t e a n d
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 33/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
2 . A n a l y z e t h e s o u r c e c o d e o f t h e p r o g r a m . W h i c h a r e t h e t w o m a i n p a r t s o f t h e
d a t a p r o c e s s i n g . I n w h i c h p r o c e s s i n g b l o c k s a r e t h e y e n c a p s u l a t e d ?
3 . T h e d a ta c o m e fro m d a ta b a s e ta b le s a n d
. A ll c o lu m n s b u t o n e c o m e f r o m d a t a b a s e t a b l e
. T h e r e m a i n i n g c o l u m n i s t h e r e s u l t o f
a c a lc u la tio n . A s in p u t, th i s c a l c u l a t i o n u s e s t w o e l d s o f t a b l e
. T h e s e e ld s a r e
a n d . T h e c a lc u la te d c o lu m n re tu rn s th e
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : A n a l y z e
A n a l y z e t h e p r o g r a m i n A B A P T r a c e ( S A T ) a n d i d e n t i f y t h e p r o c e s s i n g b l o c k a n d
t h e i n d i v i d u a l s t a t e m e n t w i t h t h e l a r g e s t i m p r o v e m e n t p o t e n t i a l .
1 . A n a ly z e th e p ro g ra m i n A B A P T r a c e ( S A T ) . U s e t h e d e f a u l t v a r i a n t i n
b o t h c a s e s .
2 . A n a l y z e t h e t r a c e r e s u l t . L o o k f o r t h e m o s t t i m e c o n s u m i n g p r o c e s s i n g b l o c k
( i n t e r n a l o r e x t e r n a l ) .
3 . T h e m o s t e x p e n s iv e p ro c e s s in g b lo c k i s
.
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
4 . L o o k f o r t h e m o s t e x p e n s i v e d a t a a c c e s s ( i n t e r n a l o r e x t e r n a l ) .
5 . T h e m o st e x p e n s iv e d a ta a c c e s s i s
.
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
C o n t i n u e d o n n e x t p a g e
2 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 34/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
T a s k 3 : I m p r o v e
I m p r o v e t h e p r o g r a m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , m a k e s u r e o n l y
t h o s e c o l u m n s a r e r e a d f r o m t h e d a t a b a s e w h i c h a r e a c t u a l l y n e e d e d .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . W h ic h e ld s o f ta b le S C U S T O M a r e a c t u a l l y n e e d e d ?
3 . W h ic h e ld s o f t a b le S B O O K a r e a c t u a l l y n e e d e d ?
4 . D e n e t w o l o c a l s t r u c t u r e t y p e s w i t h o n l y t h e r e q u i r e d e l d s ( s u g g e s t e d
n a m e s : l t y _ s _ b o o k a n d l t y _ s _ c u s t . U s e t h e s e t y p e s f o r t h e d a t a o b j e c t s
l s _ s c u s t o m a n d l s _ s b o o k .
5 . I n t h e t w o S E L E C T - - S t a t e m e n t s , r e p l a c e “ * ” w i t h a l i s t o f t h e r e q u i r e d e l d s .
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
T a s k 4 : Q u a n t i f y i m p r o v e m e n t
R e p e a t y o u r r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) . C o m p a r e t h e r u n t i m e
c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e rfo rm a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) a n d c o m p a r e t h e
g r o s s r u n t i m e o f t h e t w o s u b r o u t i n e s .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _ m i c r o
s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _ % .
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 35/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
S o l u t i o n 2 : I m p r o v e O p e n S Q L S t a t e m e n t s
b y U s in g F i e ld L i s t s i n s t e a d o f S E L E C T *
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C re a te a c o p y o f r e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 1 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ O S Q L _ 1 , w h e r e # # i s y o u r g r o u p
n u m b e r). A n a l y z e t h e p r o g r a m c o d e t o g e t a n i d e a i t s f u n c t i o n a l i t y . A c t i v a t e a n d
e x e c u te th e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A n a l y z e t h e s o u r c e c o d e o f t h e p r o g r a m . W h i c h a r e t h e t w o m a i n p a r t s o f t h e
d a t a p r o c e s s i n g . I n w h i c h p r o c e s s i n g b l o c k s a r e t h e y e n c a p s u l a t e d ?
A n s w e r :
1 . R e a d i n g f r o m t h e d a t a b a s e a n d c o m p u t i n g a l i s t o f c u s t o m e r s ,
s u b r o u t i n e g e t _ d a t a _ t e m p l a t e .
2 . d i s p l a y i n g t h e l i s t o f c u s t o m e r s , s u b r o u t i n e d i s p l a y .
3 . T h e d a t a c o m e f r o m d a t a b a s e t a b l e s S C U S T O M a n d S B O O K . A l l c o l u m n s
b u t o n e c o m e f r o m d a t a b a s e t a b l e S C U S T O M . T h e r e m a i n i n g c o l u m n i s t h e
r e s u l t o f a c a l c u l a t i o n . A s i n p u t , t h i s c a l c u l a t i o n u s e s t w o e l d s o f t a b l e
S B O O K . T h e s e e l d s a r e O R D E R _ D A T E a n d F L D A T E . T h e c a l c u la t e d
c o l u m n r e t u r n s t h e a v e r a g e n u m b e r o f d a y s b e t w e e n b o o k i n g d a t e a n d i g h t
d a t e .
A n s w e r : S C U S T O M , S B O O K , S C U S T O M , S B O O K , O R D E R _ D A T E ,
F L D A T E , a v e r a g e n u m b e r o f d a y s b e t w e e n b o o k i n g d a t e a n d i g h t d a t e
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
C o n t i n u e d o n n e x t p a g e
2 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 36/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
T a s k 2 : A n a l y z e
A n a l y z e t h e p r o g r a m i n A B A P T r a c e ( S A T ) a n d i d e n t i f y t h e p r o c e s s i n g b l o c k a n d
t h e i n d i v i d u a l s t a t e m e n t w i t h t h e l a r g e s t i m p r o v e m e n t p o t e n t i a l .
1 . A n a ly z e th e p ro g ra m i n A B A P T r a c e ( S A T ) . U s e t h e d e f a u l t v a r i a n t i n
b o t h c a s e s .
a ) S t a r t t r a n s a c t i o n S A T .
b ) E n te r th e n a m e o f y o u r p ro g ra m a n d , i f n e c e s s a r y , t h e n a m e o f t h e
v a r i a n t ( D E F A U L T ) .
c ) P r e s s E x e c u t e a n d w a i t .
2 . A n a l y z e t h e t r a c e r e s u l t . L o o k f o r t h e m o s t t i m e c o n s u m i n g p r o c e s s i n g b l o c k
( i n t e r n a l o r e x t e r n a l ) .
a ) O n T a b D e s k t o p 1 , d o u b l e c l i c k o n I n t e r n a l P r o c e s s i n g B l o c k s .
b ) S o r t t h e H i t l i s t o n t h e r i g h t b y c o l u m n N e t [ m i c r o s e c ] u n d l o o k f o r t h e
t o p m o s t e n t r y .
c ) R e p e a t w i t h e n t r y E x t e r n a l P r o c e s s i n g B l o c k s .
d ) A l t e r n a t i v e : S e l e c t t h e c h e c k b o x f o r b o t h e n t r i e s . F r o m t h e t o o l b a r
a b o v e P r o l e : t r a c e R e s u l t c h o o s e : D i s p l a y S u b a r e a i n H i t l i s t t o o l .
3 . T h e m o s t e x p e n s i v e p r o c e s s i n g b l o c k i s s u b r o u t i n e G E T _ D A T A _ T E M P L A T E .
A n s w e r : s u b r o u t i n e G E T _ D A T A _ T E M P L A T E
4 . L o o k f o r t h e m o s t e x p e n s i v e d a t a a c c e s s ( i n t e r n a l o r e x t e r n a l ) .
a ) R e p e a t t h e p r e v i o u s s t e p w i t h D a t a A c e s s I n t e r n a l a n d D a t a A c c e s s
E x t e r n a l .
5 . T h e m o s t e x p e n s iv e d a ta a c c e s s is F E T C H fro m D B t a b le S B O O K .
A n s w e r : F E T C H fro m D B t a b l e S B O O K
T a s k 3 : I m p r o v e
I m p r o v e t h e p r o g r a m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , m a k e s u r e o n l y
t h o s e c o l u m n s a r e r e a d f r o m t h e d a t a b a s e w h i c h a r e a c t u a l l y n e e d e d .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . W h ic h e ld s o f ta b le S C U S T O M a r e a c t u a l l y n e e d e d ?
A n s w e r : I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 37/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
3 . W h ic h e ld s o f t a b le S B O O K a r e a c t u a l l y n e e d e d ?
A n s w e r : F L D A T E , O R D E R _ D A T E
4 . D e n e t w o l o c a l s t r u c t u r e t y p e s w i t h o n l y t h e r e q u i r e d e l d s ( s u g g e s t e d
n a m e s : l t y _ s _ b o o k a n d l t y _ s _ c u s t . U s e t h e s e t y p e s f o r t h e d a t a o b j e c t s
l s _ s c u s t o m a n d l s _ s b o o k .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . I n t h e t w o S E L E C T - - S t a t e m e n t s , r e p l a c e “ * ” w i t h a l i s t o f t h e r e q u i r e d e l d s .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 4 : Q u a n t i f y i m p r o v e m e n t
R e p e a t y o u r r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) . C o m p a r e t h e r u n t i m e
c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) a n d c o m p a r e t h e
g r o s s r u n t i m e o f t h e t w o s u b r o u t i n e s .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _ m i c r o
A n s w e r :
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 1 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* W o r k A r e a f o r R e s u l t
C o n t i n u e d o n n e x t p a g e
2 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 38/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l s _ s c u s t o m T Y P E s c u s t o m ,
l s _ s b o o k T Y P E s b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T * F R O M s c u s t o m
I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
S E L E C T * F R O M s b o o k
I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d
A N D c a n c e l l e d = s p a c e .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r
l v _ c o u n t = l v _ c o u n t + 1 .
E N D S E L E C T .
I F l v _ c o u n t < > 0 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
E N D I F .
E N D S E L E C T .
S O R T c t _ c u s t o m e r s B Y i d .
E N D F O R M . "
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 39/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
E N D O F l t y _ s _ c u s t .
T Y P E S : B E G I N O F l t y _ s _ b o o k ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l s _ s c u s t o m T Y P E l t y _ s _ c u s t ,
l s _ s b o o k T Y P E l t y _ s _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
I N T O l s _ s c u s t o m .
C o n t i n u e d o n n e x t p a g e
3 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 40/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
S E L E C T f l d a t e o r d e r _ d a t e
F R O M s b o o k
I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d
A N D c a n c e l l e d = s p a c e .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r
l v _ c o u n t = l v _ c o u n t + 1 .
E N D S E L E C T .
E N D I F .
E N D S E L E C T .
S O R T c t _ c u s t o m e r s B Y i d .
E N D F O R M . "
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 3 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 41/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
3 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 42/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
E x e r c is e 3 : Im p ro v e O p e n S Q L
Sn e t a s t t e e m d e S n E t sL E b C y T U - s s t i a n t g e m a e J n o t i s n i n s t e a d o f
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• a n a ly z e a p ro g ra m w i t h C o d e I n s p e c t o r ( S C I ) t o d e t e c t p o t e n t i a l p e r f o r m a n c e
p r o b l e m s
• d e c r e a s e t h e r u n t i m e f o r d a t a b a s e s e l e c t s b y u s i n g a j o i n i n s t e a d o f n e s t e d
S E L E C T - S t a t e m e n t s
• q u a n ti f y t h e i m p r o v e m e n t w i t h A B A P T r a c e ( S A T )
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 2
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 2
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 2 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ O S Q L _ 2 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : A n a l y z e
A n a ly z e th e p r o g r a m w i t h C o d e I n s p e c t o r ( S C I ) t o i d e n t i f y p o t e n t i a l p e r f o r m a n c e
p r o b l e m s .
1 . C r e a t e a l o c a l c h e c k v a r i a n t f o r C o d e I n s p e c t o r ( s u g g e s t e d n a m e :
H A 4 0 0 _ P E R F # # , w h e r e # # i s y o u r g r o u p n u m b e r ) . I n t h e c h e c k v a r i a n t
a c t i v a t e a l l p e r f o r m a n c e c h e c k s .
2 . P e r f o r m a n I n s p e c t i o n o f y o u r p r o g r a m b a s e d o n y o u r n e w c h e c k v a r i a n t
( s u g g e s t e d n a m e f o r t h e i n s p e c t i o n : H A 4 0 0 _ O S Q L # # ) . .
3 . A n a l y z e t h e i n s p e c t i o n r e s u l t . N a v i g a t e t o t h e A B A P S o u r c e C o d e . W h a t
c a n b e d o n e a b o u t t h e r e p o r t e d i s s u e ?
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 3 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 43/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
T a s k 3 : I m p r o v e
I m p r o v e t h e p r o g r a m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e t w o
n e s t e d S E L E C T - l o o p s b y o n e S E L E C T o n b o t h d a t a b a s e t a b l e s ( J o i n ) .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . D e n e o n e l o c a l s t r u c t u r e t y p e w i t h a l l r e q u i r e d e l d s f r o m b o t h t a b l e s
( s u g g e s t e d n a m e : l t y _ s _ c u s t _ b o o k . D e c l a r e a s t r u c t u r e a n d a n i n t e r n a l t a b l e
b a s e d o n t h i s t y p e ( s u g g e s t e d n a m e : l s _ c u s t _ b o o k ) .
3 . R e m o v e th e tw o S E L E C T -s ta te m e n ts , b y ju s t o n e S E L E C T - S t a t e m e n t .
C o m b in e th e d a ta fro m S B O O K a n d S C U S T O M t h r o u g h a n i n n e r j o in
w ith a su i t a b l e jo i n c o n d itio n . A d ju s t th e e l d l i s t a n d u s e i n t e r n a l t a b l e
lt_ c u s t_ b o o k a s t a rg e t f o r th e s e le c t s ta te m e n t .
4 . O p t i o n a l : U s e a l i a s e s f o r t h e t w o t a b l e s t o i m p r o v e r e a d a b i l i t y a n d a d d t h e
t a b l e n a m e s i n t e h e l d l i s t a n d W H E R E - c l a u s e .
5 . I n a l o o p o v e r l t _ c u s t _ b o o k , i m p l e m e n t t h e c a l c u l a t i o n o f t h e a v e r a g e d a y s
b e t w e e n o r d e r d a t e a n d i g h t d a t e a n d l l t a b l e c t _ c u s t o m e r s w i t h t h e r e s u l t .
H i n t : F i r s t m a k e s u r e t h e d a t a i s s o r t e d b y c o l u m n I D
. W h e n e v e r y o u
r e a c h a n e w c u s t o m e r , n i s h s u m m i n g u p t h e d a y d i f f e r e n c e s , d i v i d e
b y t h e n u m b e r o f b o o k i n g s a n d i n s e r t a n e w l i n e i n c t _ c u s t o m e r s .
T h e n s ta rt w ith th e n e w c u s t o m e r .
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
T a s k 4 : Q u a n t i f y i m p r o v e m e n t
P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) . C o m p a r e t h e r u n t i m e
c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) a n d c o m p a r e t h e
g r o s s r u n t i m e o f t h e t w o s u b r o u t i n e s .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _ m i c r o
s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _ % .
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
3 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 44/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
S o l u t i o n 3 : I m p r o v e O p e n S Q L S t a t e m e n t s
bS y E L U E s C i n T g - s a t a J t e o m i n e ni n t ss t e a d o f n e s t e d
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 2 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ O S Q L _ 2 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : A n a l y z e
A n a ly z e th e p r o g r a m w i t h C o d e I n s p e c t o r ( S C I ) t o i d e n t i f y p o t e n t i a l p e r f o r m a n c e
p r o b l e m s .
1 . C r e a t e a l o c a l c h e c k v a r i a n t f o r C o d e I n s p e c t o r ( s u g g e s t e d n a m e :
H A 4 0 0 _ P E R F # # , w h e r e # # i s y o u r g r o u p n u m b e r ) . I n t h e c h e c k v a r i a n t
a c t i v a t e a l l p e r f o r m a n c e c h e c k s .
a ) S t a r t t r a n s a c t i o n S C I .
b ) I n F r a m e C h e c k V a r i a n t , e n t e r t h e c h e c k v a r i a n t n a m e a n d c l i c k o n
b u t t o n C r e a t e .
c ) I n t h e c h e c k v a r i a n t , m a k e s u r e a l l P e r f o r m a n c e C h e c k s a r e s e l e c t e d .
S a v e t h e c h e c k v a r i a n t a n d g o b a c k t o t h e s t a r t s c r e e n o f t r a n s a c t i o n S C I .
2 . P e r f o r m a n I n s p e c t i o n o f y o u r p r o g r a m b a s e d o n y o u r n e w c h e c k v a r i a n t
( s u g g e s t e d n a m e f o r t h e i n s p e c t i o n : H A 4 0 0 _ O S Q L # # ) . .
a ) S t a r t t r a n s a c t i o n S C I .
b ) I n F r a m e I n s p e c t i o n , e n t e r t h e n a m e f o r t h e i n s p e c t i o n a n d c l i c k o n
b u t t o n C r e a t e .
c ) I n f r a m e O b j e c t S e l e c t i o n , e n t e r S i n g l e , P r o g r a m a n d t y p e i n t h e n a m e
o f y o u r p r o g r a m .
d ) I n f r a m e C h e c k V a r i a n t , e n t e r t h e n a m e o f y o u r c h e c k v a r i a n t .
e ) O n t h e t o o l b a r , c l i c k o n t h e b u t t o n l a b e l l e d E x e c u t e ( F 8 ) .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 3 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 45/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
T a s k 3 : I m p r o v e
I m p r o v e t h e p r o g r a m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
sn u e b s t r e o d u t S i n E e L g E e C t _ T d - a l o t a o _ p s s o b l u y t i o o n n e . S I nE L s u E b C r o T u o t i n n e b o g t e h t _ d d a a t at a b _ a s s o e l ut a t ib o l en s , r ( eJ o p il na c) . e t h e t w o
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . D e n e o n e l o c a l s t r u c t u r e t y p e w i t h a l l r e q u i r e d e l d s f r o m b o t h t a b l e s
( s u g g e s t e d n a m e : l t y _ s _ c u s t _ b o o k . D e c l a r e a s t r u c t u r e a n d a n i n t e r n a l t a b l e
b a s e d o n t h i s t y p e ( s u g g e s t e d n a m e : l s _ c u s t _ b o o k ) .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
3 . RC eo m m ob v i n e e t ht h e e t w d a o t a S fE r Lo m E C S T B - O s t aO t eK m a e n n d t s S , Cb y U jS u T s Ot o M n e t h S r E o L u g E h C aT n - S i tn a n t ee rm j e o n i n t .
w ith a su i t a b l e jo i n c o n d itio n . A d ju s t th e e l d l i s t a n d u s e i n t e r n a l t a b l e
lt_ c u s t_ b o o k a s t a r g e t f o r th e s e le c t s ta te m e n t .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
4 . O p t i o n a l : U s e a l i a s e s f o r t h e t w o t a b l e s t o i m p r o v e r e a d a b i l i t y a n d a d d t h e
t a b l e n a m e s i n t e h e l d l i s t a n d W H E R E - c l a u s e .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . I n a l o o p o v e r l t _ c u s t _ b o o k , i m p l e m e n t t h e c a l c u l a t i o n o f t h e a v e r a g e d a y s
b e t w e e n o r d e r d a t e a n d i g h t d a t e a n d l l t a b l e c t _ c u s t o m e r s w i t h t h e r e s u l t .
H i n t : F i r s t m a k e s u re th e d a ta i s s o r t e d b y c o l u m n I D
. W h e n e v e r y o u
r e a c h a n e w c u s to m e r, n is h s u m m i n g u p t h e d a y d i f f e r e n c e s , d i v i d e
b y th e n u m b e r o f b o o k in g s a n d i n s e r t a n e w l i n e i n c t _ c u s t o m e r s .
T h e n s ta rt w ith th e n e w c u sto m e r .
C o n t i n u e d o n n e x t p a g e
3 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 46/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 4 : Q u a n t i f y i m p r o v e m e n t
P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) . C o m p a r e t h e r u n t i m e
c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) a n d c o m p a r e t h e
g r o s s r u n t i m e o f t h e t w o s u b r o u t i n e s .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _ m i c r o
s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _ % .
A n s w e r :
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 2 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
E N D O F l t y _ s _ c u s t .
T Y P E S : B E G I N O F l t y _ s _ b o o k ,
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 3 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 47/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l s _ s c u s t o m T Y P E l t y _ s _ c u s t ,
l s _ s b o o k T Y P E l t y _ s _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
S E L E C T f l d a t e o r d e r _ d a t e
F R O M s b o o k
I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d
A N D c a n c e l l e d = s p a c e .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r _ d a t
l v _ c o u n t = l v _ c o u n t + 1 .
E N D S E L E C T .
C o n t i n u e d o n n e x t p a g e
3 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 48/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
E N D I F .
E N D S E L E C T .
S O R T c t _ c u s t o m e r s B Y i d .
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t _ b o o k ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ c u s t _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l t _ c u s t _ b o o k T Y P E S O R T E D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d ,
l s _ c u s t _ b o o k T Y P E l t y _ s _ c u s t _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 3 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 49/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
C L E A R c t _ c u s t o m e r s .
S E L E C T c ~ i d c ~ n a m e c ~ p o s t c o d e c ~ c i t y c ~ c o u n t r y b ~ f l d a t e b ~ o r d e r _ d a t e
F R O M s c u s t o m A S c I N N E R J O I N s b o o k A S b
O N c ~ i d = b ~ c u s t o m i d
I N T O T A B L E l t _ c u s t _ b o o k
W H E R E b ~ c a n c e l l e d = s p a c e .
L O O P A T l t _ c u s t _ b o o k I N T O l s _ c u s t _ b o o k .
I F s y - t a b i x = 1 . " f i r s t b o o k i n g o f f i r s t c u s t o m e r
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
E N D I F .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ c u s t _ b o o k - f l d a t e - l s _ c u s t _ b o o k - o r d
l v _ c o u n t = l v _ c o u n t + 1 .
E N D L O O P .
* S t o r e l a s t e n t r y i n r e s u l t t a b l e
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
* S O R T c t _ c u s t o m e r s B Y i d . " n o t n e e d e d , a l r e a d y s o r t e d
C o n t i n u e d o n n e x t p a g e
4 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 50/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
E N D F O R M . "
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 4 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 51/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
4 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 52/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
E x e r c is e 4 : I m p r o v e O p e n S Q L S t a t e m e n t s
b y b u f f e r i n g a l l d a t a y o u n e e d
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• a n a ly z e a p ro g ra m w i t h S Q L T r a c e ( S T 0 5 ) t o d e t e c t r e p e a t e d s e l e c t s
• d e c r e a s e t h e r u n t i m e f o r d a t a b a s e s e l e c t s b y b u f f e r i n g d a t a i n i n t e r n a l t a b l e s
• q u a n ti f y t h e i m p r o v e m e n t w i t h A B A P T r a c e ( S A T )
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 3
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 3
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 3 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ O S Q L _ 3 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : A n a l y z e
A n a ly z e th e p r o g r a m w i t h S Q L T r a c e ( S T 0 5 ) t o d e t e c t r e p e a t e d s e l e c t s
1 . I n a s e p a r a t e s e s s i o n ( w i n d o w ) , s w i t c h o n S Q L T r a c e w i t h a l t e r f o r y o u r
u s e r n a m e a n d y o u r p r o g r a m .
2 . E x e c u te y o u r p r o g ra m a n d s w i t c h o f f S Q L T r a c e a s s o o n a s p o s s i b l e .
3 . A n a l y z e t h e t r a c e r e s u l t a n d i d e n t i f y t h e m o s t e x p e n s i v e s t a t e m e n t a n d
r e p e a t e d S E L E C T s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 4 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 53/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
T a s k 3 : I m p r o v e
I m p ro v e th e p ro g ra m . C o p y th e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e t w o
n e s te d S E L E C T - lo o p s b y tw o a rr a y f e t c h e s o n S C U S T O M a n d S B O O K a n d t w o
n e s te d lo o p s o v e r th e in te rn a l ta b l e s .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . D e n e t w o i n t e r n a l t a b l e s ( s u g g e s t e d n a m e s : l t _ s c u s t o m a n d l t _ s b o o k , w i t h
l i n e t y p e s l t y _ s _ b o o k a n d l t y _ s _ c u s t . M a k e s u r e y o u d e n e t h e t a b l e s a s
s o r t e d t a b l e s w i t h t a b l e k e y I D o r C U S T O M I D
3 . W h y i s i t i m p o r t a n t t o d e n e t h e t w o t a b l e s a s s o r t e d t a b l e s ?
4 . B e f o r e t h e t w o S E L E C T - l o o p s , i m p l e m e n t t w o S E L E C T - s t a t e m e n t s t o r e a d
a l l c u s t o m e r s a n d a l l n o n - c a n c e l l e d b o o k i n g s i n t o t h e i n t e r n a l t a b l e s . R e p l a c e
t h e S E L E C T - l o o p s w i t h L O O P s o v e r t h e i n t e r n a l t a b l e s .
5 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
T a s k 4 : Q u a n t i f y I m p r o v e m e n t
P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) . C o m p a r e t h e r u n t i m e
c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) a n d c o m p a r e t h e
g r o s s r u n t i m e o f t h e t w o s u b r o u t i n e s .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _ m i c r o
s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _ % .
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
3 . O p t i o n a l : C h a n g e t h e d e c l a r a t i o n o f l t _ s b o o k f r o m s o r t e d t a b l e t o s t a n d a r d
t a b l e a n d r e p e a t t h e m e a s u r e m e n t .
4 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 54/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
S o l u t i o n 4 : I m p r o v e O p e n S Q L S t a t e m e n t s
b y b u f f e r i n g a l l d a t a y o u n e e d
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ T 3 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ O S Q L _ 3 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : A n a l y z e
A n a ly z e th e p r o g r a m w i t h S Q L T r a c e ( S T 0 5 ) t o d e t e c t r e p e a t e d s e l e c t s
1 . I n a s e p a r a t e s e s s i o n ( w i n d o w ) , s w i t c h o n S Q L T r a c e w i t h a l t e r f o r y o u r
u s e r n a m e a n d y o u r p r o g r a m .
a ) S t a r t t r a n s a c t i o n S T 0 5 i n a n e w s e s s i o n ( e n t e r / o S T 0 5 i n t h e c o m m a n d
e l d ) .
b ) C h o o s e A c t i v a t e T r a c e w i t h F i l t e r .
c ) E n t e r y o u r u s e r a n d p r o g r a m n a m e a n d c h o o s e E n t e r .
2 . E x e c u te y o u r p r o g ra m a n d s w i t c h o f f S Q L T r a c e a s s o o n a s p o s s i b l e .
a ) R e t u r n t o t h e r s t s e s s i o n ( w i n d o w ) a n d e x e c u t e y o u r p r o g r a m .
b ) A s s o o n a s p o s s i b l e , r e t u r n t o t h e S Q L T r a c e a n d c h o o s e D e a c t i v a t e .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 4 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 55/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
3 . A n a l y z e t h e t r a c e r e s u l t a n d i d e n t i f y t h e m o s t e x p e n s i v e s t a t e m e n t a n d
r e p e a t e d S E L E C T s .
a ) I n S Q L T r a c e , c h o o s e D i s p l a y T r a c e a n d E x e c u t e ( F 8 ) t o s e e t h e t r a c e
r e s u l t .
b ) F r o m t h e m e n u , c h o o s e T r a c e L i s t → S u m m a r i z e T r a c e b y S Q L
S t a t e m e n t .
c ) S o r t t h e l i s t b y c o l u m n D u r a t i o n a n d i d e n t i f y t h e m o s t e x p e n s i v e
s t a t e m e n t .
d ) S o r t t h e l i s t b y c o l u m n E x e c u t i o n s a n d i d e n t i f y t h e s t a t e m e n t t h a t h a s
b e e n r e p e a t e d m o s t o f t e n .
e ) C l i c k o n t h e s t a t e m e n t a n d c h o o s e D i s p l a y c a l l p o s i t i o n s i n A B A P
p r o g r a m f r o m t h e t o o l b a r .
T a s k 3 : I m p r o v e
I m p ro v e th e p ro g ra m . C o p y th e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e t w o
n e s te d S E L E C T - lo o p s b y tw o a rr a y f e t c h e s o n S C U S T O M a n d S B O O K a n d t w o
n e s te d lo o p s o v e r th e in te rn a l ta b l e s .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . D e n e t w o i n t e r n a l t a b l e s ( s u g g e s t e d n a m e s : l t _ s c u s t o m a n d l t _ s b o o k , w i t h
l i n e t y p e s l t y _ s _ b o o k a n d l t y _ s _ c u s t . M a k e s u r e y o u d e n e t h e t a b l e s a s
s o r t e d t a b l e s w i t h t a b l e k e y I D o r C U S T O M I D
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
3 . W h y i s i t i m p o r t a n t t o d e n e t h e t w o t a b l e s a s s o r t e d t a b l e s ?
A n s w e r : O t h e r w i s e t h e r u n t i m e e n v i r o n m e n t w o u l d n o t b e a b l e t o o p t i m i z e
t h e l o o p s o v e r t h e s e t a b l e s a n d w e w o u l d l o o s e a l o t o f r u n t i m e b y s e a r c h i n g
f o r t h e n e c e s s a r y e n t r i e s .
4 . B e f o r e t h e t w o S E L E C T - l o o p s , i m p l e m e n t t w o S E L E C T - s t a t e m e n t s t o r e a d
a l l c u s t o m e r s a n d a l l n o n - c a n c e l l e d b o o k i n g s i n t o t h e i n t e r n a l t a b l e s . R e p l a c e
t h e S E L E C T - l o o p s w i t h L O O P s o v e r t h e i n t e r n a l t a b l e s .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
C o n t i n u e d o n n e x t p a g e
4 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 56/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
T a s k 4 : Q u a n t i f y I m p r o v e m e n t
P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) . C o m p a r e t h e r u n t i m e
c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) a n d c o m p a r e t h e
g r o s s r u n t i m e o f t h e t w o s u b r o u t i n e s .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _ m i c r o
s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _ % .
A n s w e r :
3 . O p t i o n a l : C h a n g e t h e d e c l a r a t i o n o f l t _ s b o o k f r o m s o r t e d t a b l e t o s t a n d a r d
t a b l e a n d r e p e a t t h e m e a s u r e m e n t .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 3 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
E N D O F l t y _ s _ c u s t .
T Y P E S : B E G I N O F l t y _ s _ b o o k ,
f l d a t e T Y P E s b o o k - f l d a t e ,
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 4 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 57/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l s _ s c u s t o m T Y P E l t y _ s _ c u s t ,
l s _ s b o o k T Y P E l t y _ s _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
S E L E C T f l d a t e o r d e r _ d a t e
F R O M s b o o k
I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d
A N D c a n c e l l e d = s p a c e .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r _ d a t
l v _ c o u n t = l v _ c o u n t + 1 .
E N D S E L E C T .
C o n t i n u e d o n n e x t p a g e
4 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 58/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
E N D I F .
E N D S E L E C T .
S O R T c t _ c u s t o m e r s B Y i d .
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
E N D O F l t y _ s _ c u s t .
T Y P E S : B E G I N O F l t y _ s _ b o o k ,
c u s t o m i d T Y P E s b o o k - c u s t o m i d ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l t _ s c u s t o m T Y P E S O R T E D T A B L E O F l t y _ s _ c u s t W I T H N O N - U N I Q U E K E Y i d ,
l s _ s c u s t o m T Y P E l t y _ s _ c u s t ,
l t _ s b o o k T Y P E S O R T E D T A B L E O F l t y _ s _ b o o k W I T H N O N - U N I Q U E K E Y c u s t o m i d ,
l s _ s b o o k T Y P E l t y _ s _ b o o k .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 4 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 59/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
I N T O T A B L E l t _ s c u s t o m .
* O R D E R B Y i d n o i m p r o v e m e n t , s o r t i n g o n A p p l . s e r v e r m o r e e f f i c i e n t
S E L E C T c u s t o m i d f l d a t e o r d e r _ d a t e
F R O M s b o o k
I N T O T A B L E l t _ s b o o k
W H E R E c a n c e l l e d = s p a c e .
* O R D E R B Y c u s t o m i d n o i m p r o v e m e n t , s o r t i n g o n A p p l . s e r v e r m o r e e f f i c i e n t
L O O P A T l t _ s c u s t o m I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
L O O P A T l t _ s b o o k I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r _ d a t
l v _ c o u n t = l v _ c o u n t + 1 .
E N D L O O P .
I F l v _ c o u n t > 0 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
E N D I F .
E N D L O O P .
* S O R T c t _ c u s t o m e r s B Y i d . " a l r e a d y s o r t e d
E N D F O R M . "
5 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 60/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O p tim iz e C o n v e n tio n a l C o d e
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• U n d e r s t a n d t h e R u n t i m e A n a l y s i s ( S E 3 0 )
• U n d e r s t a n d t h e A B A P T r a c e ( S A T )
• U n d e r s t a n d t h e C o d e I n s p e c t o r ( S C I )
• U n d e r s t a n d t h e S Q L T r a c e ( S T 0 5 )
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 5 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 61/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
L e s s o n : A c c e s s t h e S A P H A N A D a t a b a s e U s in g O p e n
S Q L a n d S e c o n d a r y C o n n e c t i o n
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• D e s c rib e h o w to a c c e s s th e S A P H A N A D a t a b a s e b y u s i n g O p e n S Q L a n d a
s e c o n d a r y d a t a b a s e c o n n e c t i o n
B u s i n e s s E x a m p l e
F ig u r e 2 3 : R e c a p : H A N A E v o lu t i o n
5 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 62/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : A c c e s s th e S A P H A N A D a ta b a s e U s in g O p e n S Q L a n d S e c o n d a r y C o n n e c t io n
F i g u r e 2 4 : S e c o n d a r y D a t a b a s e C o n n e c t i o n s
F i g u r e 2 5 : T r a n s a c t i o n D B A C O C K P I T
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 5 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 63/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
F i g u r e 2 6 : O p e n S Q L U s in g S e c o n d a r y D a t a b a s e C o n n e c t i o n
F i g u r e 2 7 : R e s t r i c t i o n
5 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 64/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : A c c e s s th e S A P H A N A D a ta b a s e U s in g O p e n S Q L a n d S e c o n d a r y C o n n e c t io n
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• D e s c rib e h o w to a c c e s s th e S A P H A N A D a t a b a s e b y u s i n g O p e n S Q L a n d a
s e c o n d a r y d a t a b a s e c o n n e c t i o n
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 5 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 65/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
L e s s o n : T a b le s in S A P H A N A S t u d io
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• U n d e r s ta n d S c h e m a ta a n d T a b le s in S A P H A N A S t u d io
• A n a ly z e th e D e n itio n o f T a b le s in S A P H A N A S t u d io
B u s i n e s s E x a m p l e
F ig u r e 2 8 : S A P H A N A S t u d io : S c h e m a a n d T a b le
5 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 66/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
F i g u r e 2 9 : T a b l e D e n i t i o n
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 5 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 67/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
5 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 68/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
E x e r c is e 5 : A c c e s s S A P H A N A v ia a
s e c o n d a r y D a t a b a s e C o n n e c t i o n
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• u n d e rs ta n d h o w s e c o n d a r y d a t a b a s e c o n n e c t i o n s a r e m a i n t a i n e d t e s t e d
• u n d e r s t a n d t h e p r e r e q u i s i t e s t o a c c e s s t a b l e s o f t h e s e c o n d a r y d a t a b a s e v i a
o p e n S Q L
• q u a n t i f y v a r i o u s i m p r o v e m e n t s o f d a t a b a s e a c c e s s e s f o r S A P H A N A
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 1
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 2
R e p o r t Y H A 4 0 0 _ O P T I M I Z E _ O S Q L _ S 3
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ S E C _ D B _ C O N _ S 1
R e p o r t Y H A 4 0 0 _ S E C _ D B _ C O N _ S 2
R e p o r t Y H A 4 0 0 _ S E C _ D B _ C O N _ S 3
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e s
C re a te c o p ie s o f r e p o rts Y H A 4 0 0 _ O P T IM IZ E _ O S Q L _ S 1 ,Y H A 4 0 0 _ O P -
T IM IZ E _ O S Q L _ S 2 a n d Y H A 4 0 0 _ O P T IM IZ E _ O S Q L _ S 3 in y o u r
p a c k a g e Z H A 4 0 0 _ # # (s u g g e s te d n a m e s: Z H A 4 0 0 _ # # _ S E C _ D B _ 1 ,
Z H A 4 0 0 _ # # _ S E C _ D B _ 2 , Z H A 4 0 0 _ # # _ S E C _ D B _ 3 , w h ere # # i s y o u r g r o u p
n u m b e r ) . A c tiv a te th e p r o g r a m s .
H i n t : A l t e r n a t i v e l y , y o u m a y u s e y o u r o w n s o l u t i o n s f r o m t h e p r e v i o u s
t h r e e e x e r c i s e s a s t e m p l a t e s f o r t h i s e x e r c i s e .
1 . C r e a te c o p ie s o f t h e r e p o rts . P l a c e th e m i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d
a s s i g n t h e m t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e t h e p r o g r a m s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 5 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 69/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
T a s k 2 : A n a l y z e
L o o k f o r a s e c o n d a r y d a t a b a s e c o n n e c t i o n t h a t p o i n t s t o t h e S A P H A N A s e r v e r .
F i n d o u t w h i c h t a b l e s c a n b e a c c e s s e d v i a t h i s c o n n e c t i o n u s i n g o p e n S Q L .
1 . L o o k u p t h e s e c o n d a r y d a t a b a s e c o n n e c t i o n s w h i c h h a v e b e e n m a i n t a i n e d i n
y o u r A S A B A P .
2 . F i n d a d a ta b a s e c o n n e c tio n th a t p o in ts to y o u r S A P H A N A s e r v e r a n d n o te
d o w n u s e r a n d c o n n e c t i o n I D .
3 . T h e c o n n e c tio n ID is a n d th e u s e r fo r th e S A P H A N A
s e r v e r i s
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
4 . G o t o S A P H A N A S tu d i o a n d o p e n t h e s c h e m a o f t h e s a m e n a m e a s t h e u s e r
i n t h e d a t a b a s e c o n n e c t i o n .
5 . L o o k f o r t h e t a b l e s y o u n d i n t h i s s c h e m a . T h o s e a r e t h e o n e s y o u c a n
a c c e s s v i a t h e s e c o n d a r y d a t a b a s e c o n n e c t i o n u s i n g o p e n S Q L .
6 . T h e t a b le s a r e :
T a s k 3 : A c c e s s S A P H A N A
C h a n g e y o u r t h r e e p r o g r a m s . I n a l l s e l e c t s t a t e m e n t s ( s u b r o u t i n e s
g e t _ d a t a _ s o l u t i o n a n d s u b r o u t i n e g e t _ d a t a _ t e m p l a t e ) r e a d f r o m S A P H A N A
r a t h e r t h a n t h e p r i m a r d a t a b a s e .
1 . E d i t y o u r p r o g r a m Z H A 4 0 0 _ # # _ S E C _ D B _ 1 . S e a r c h f o r a l l
S E L E C T - s t a t m e n t s a n d u s e a d d i t i o n C O N N E C T I O N t o a c c e s s t h e s e c o n d a r y
d a t a b a s e r a t h e r t h a n t h e p r i m a r y d a t a b a s e .
H i n t : I n s t e a d o f h a r d c o d i n g t h e c o n n e c t i o n i t i s r e c o m m e n d e d t o
d e n e a g l o b a l c o n s t a n t o f t y p e s t r i n g .
2 . R e p e a t w i t h p r o g r a m s Z H A 4 0 0 _ # # _ S E C _ D B _ 2 a n d
Z H A 4 0 0 _ # # _ S E C _ D B _ 3 .
C o n t i n u e d o n n e x t p a g e
6 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 70/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
3 . A c t i v a t e a n d t e s t y o u r p r o g r a m s .
T a s k 4 : Q u a n t i f y i m p r o v e m e n t s w h e n u s in g S A P
H A N A a s d a t a b a s e
P e r f o r m r u n t i m e m e a s u r e m e n t s w i t h A B A P T r a c e ( S A T ) f o r a l l t h r e e p r o g r a m s .
I n e a c h c a s e , c o m p a r e t h e r u n t i m e c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e
a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) f o r p r o g r a m
Z H A 4 0 0 _ # # _ S E C _ D B _ 1 a n d c o m p a r e t h e g r o s s r u n ti m e o f t h e t w o
s u b r o u t i n e s .
2 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s :
_ _ _ _ _ _ _ _ _ _ _ m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _
% t h r o u g h t h e u s a g e o f e l d l i s t s
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
3 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) f o r p r o g r a m
Z H A 4 0 0 _ # # _ S E C _ D B _ 2 a n d c o m p a r e t h e g r o s s r u n ti m e o f t h e t w o
s u b r o u t i n e s .
4 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s :
_ _ _ _ _ _ _ _ _ _ _ m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _
% t h r o u g h t h e u s a g e o f a j o i n i n s t e a d o f n e s t e d s e l e c t s .
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
5 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) f o r p r o g r a m
Z H A 4 0 0 _ # # _ S E C _ D B _ 3 a n d c o m p a r e t h e g r o s s r u n ti m e o f t h e t w o
s u b r o u t i n e s .
6 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s :
_ _ _ _ _ _ _ _ _ _ _ m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _
% t h r o u g h t h e u s a g e o f f u l l b u f f e r i n g i n s t e a d o f n e s t e d s e l e c t s .
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 6 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 71/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
S o lu tio n 5 : A c c e s s S A P H A N A v ia a
s e c o n d a r y D a t a b a s e C o n n e c t i o n
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e s
C re a te c o p ie s o f r e p o rts Y H A 4 0 0 _ O P T IM IZ E _ O S Q L _ S 1 ,Y H A 4 0 0 _ O P -
T IM IZ E _ O S Q L _ S 2 a n d Y H A 4 0 0 _ O P T IM IZ E _ O S Q L _ S 3 in y o u r
p a c k a g e Z H A 4 0 0 _ # # (s u g g e s te d n a m e s: Z H A 4 0 0 _ # # _ S E C _ D B _ 1 ,
Z H A 4 0 0 _ # # _ S E C _ D B _ 2 , Z H A 4 0 0 _ # # _ S E C _ D B _ 3 , w h ere # # i s y o u r g r o u p
n u m b e r ) . A c tiv a te th e p r o g r a m s .
H i n t : A l t e r n a t i v e l y , y o u m a y u s e y o u r o w n s o l u t i o n s f r o m t h e p r e v i o u s
t h r e e e x e r c i s e s a s t e m p l a t e s f o r t h i s e x e r c i s e .
1 . C r e a te c o p ie s o f t h e r e p o rts . P l a c e th e m i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d
a s s i g n t h e m t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e t h e p r o g r a m s .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : A n a l y z e
L o o k f o r a s e c o n d a r y d a t a b a s e c o n n e c t i o n t h a t p o i n t s t o t h e S A P H A N A s e r v e r .
F i n d o u t w h i c h t a b l e s c a n b e a c c e s s e d v i a t h i s c o n n e c t i o n u s i n g o p e n S Q L .
1 . L o o k u p t h e s e c o n d a r y d a t a b a s e c o n n e c t i o n s w h i c h h a v e b e e n m a i n t a i n e d i n
y o u r A S A B A P .
a ) S t a r t t r a n s a c t i o n S M 3 0 .
b ) E n t e r D B C O N a s t a b l e n a m e a n d c h o o s e D i s p l a y .
2 . F i n d a d a ta b a s e c o n n e c tio n th a t p o in ts to y o u r S A P H A N A s e r v e r a n d n o te
d o w n u s e r a n d c o n n e c t i o n I D .
a ) O n t h e l i s t , l o o k f o r a c o n n e c t i o n w i t h H D B i n c o l u m n D B S .
b ) M a k e s u r e t h e s e r v e r i n c o l u m n c o n n e c t i o n i n f o r m a t i o n i s r i g h t .
3 . T h e c o n n e c t i o n I D i s S F L I G H T a n d t h e u s e r f o r t h e S A P H A N A s e r v e r
i s S F L I G H T
A n s w e r : S F L I G H T , S F L I G H T
C o n t i n u e d o n n e x t p a g e
6 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 72/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
4 . G o t o S A P H A N A S tu d i o a n d o p e n t h e s c h e m a o f t h e s a m e n a m e a s t h e u s e r
i n t h e d a t a b a s e c o n n e c t i o n .
a ) In S A P H A N A S t u d i o , o p e n p e r s p e c t i v e M o d e l e r .
b ) In th e N a v ig a tio n w in d o w o n t h e l e f t , o p e n C a t a l o g - > S F L I G H T .
5 . L o o k f o r t h e t a b l e s y o u n d i n t h i s s c h e m a . T h o s e a r e t h e o n e s y o u c a n
a c c e s s v i a t h e s e c o n d a r y d a t a b a s e c o n n e c t i o n u s i n g o p e n S Q L .
a ) U n d e r s c h e m a S F L I G H T , o p e n n o d e t a b l e s .
6 . T h e t a b le s a r e :
A n s w e r : M A R A , S B O O K , S A R R , S C U S T O M , S F L I G H T , S P F L I , T C U R F ,
T C U R R , T C U R V , T C U R X
T a s k 3 : A c c e s s S A P H A N A
C h a n g e y o u r t h r e e p r o g r a m s . I n a l l s e l e c t s t a t e m e n t s ( s u b r o u t i n e s
g e t _ d a t a _ s o l u t i o n a n d s u b r o u t i n e g e t _ d a t a _ t e m p l a t e ) r e a d f r o m S A P H A N A
r a t h e r t h a n t h e p r i m a r d a t a b a s e .
1 . E d i t y o u r p r o g r a m Z H A 4 0 0 _ # # _ S E C _ D B _ 1 . S e a r c h f o r a l l
S E L E C T - s t a t m e n t s a n d u s e a d d i t i o n C O N N E C T I O N t o a c c e s s t h e s e c o n d a r y
d a t a b a s e r a t h e r t h a n t h e p r i m a r y d a t a b a s e .
H i n t : I n s t e a d o f h a r d c o d i n g t h e c o n n e c t i o n i t i s r e c o m m e n d e d t o
d e n e a g l o b a l c o n s t a n t o f t y p e s t r i n g .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
2 . R e p e a t w i t h p r o g r a m s Z H A 4 0 0 _ # # _ S E C _ D B _ 2 a n d
Z H A 4 0 0 _ # # _ S E C _ D B _ 3 .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
3 . A c t i v a t e a n d t e s t y o u r p r o g r a m s .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 6 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 73/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
T a s k 4 : Q u a n t i f y i m p r o v e m e n t s w h e n u s in g S A P
H A N A a s d a t a b a s e
P e r f o r m r u n t i m e m e a s u r e m e n t s w i t h A B A P T r a c e ( S A T ) f o r a l l t h r e e p r o g r a m s .
I n e a c h c a s e , c o m p a r e t h e r u n t i m e c o n s u m p t i o n o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e
a n d s u b r o u t i n e g e t _ d a t a _ s o l u t i o n
1 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) f o r p r o g r a m
Z H A 4 0 0 _ # # _ S E C _ D B _ 1 a n d c o m p a r e t h e g r o s s r u n ti m e o f t h e t w o
s u b r o u t i n e s .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . T h e g ro s s ru n tim e o f s u b ro u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _
m ic ro s e c o n d s . T h e g ro s s ru n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s :
_ _ _ _ _ _ _ _ _ _ _ m ic ro se c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _
% th ro u g h th e u s a g e o f e ld l i s t s
A n s w e r :
3 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) f o r p r o g r a m
Z H A 4 0 0 _ # # _ S E C _ D B _ 2 a n d c o m p a r e t h e g r o s s r u n ti m e o f t h e t w o
s u b r o u t i n e s .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
4 . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _
m i c r o s e c o n d s . T h e g r o s s r u n t i m e o f s u b r o u t i n e g e t _ d a t a _ s o l u t i o n i s :
_ _ _ _ _ _ _ _ _ _ _ m i c r o s e c o n d s . T h i s i s a r e d u c t i o n o f t h e r u n t i m e b y _ _ _ _ _ _
% t h r o u g h t h e u s a g e o f a j o i n i n s t e a d o f n e s t e d s e l e c t s .
A n s w e r :
5 . P e r f o r m a r u n t i m e m e a s u r e m e n t w i t h A B A P T r a c e ( S A T ) f o r p r o g r a m
Z H A 4 0 0 _ # # _ S E C _ D B _ 3 a n d c o m p a r e t h e g r o s s r u n ti m e o f t h e t w o
s u b r o u t i n e s .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
6 . T h e g ro s s ru n tim e o f s u b ro u t i n e g e t _ d a ta _ te m p l a t e i s : _ _ _ _ _ _ _ _ _ _ _
m ic ro s e c o n d s . T h e g ro s s ru n tim e o f su b ro u t i n e g e t _ d a t a _ s o l u t i o n i s :
_ _ _ _ _ _ _ _ _ _ _ m ic ro se c o n d s . T h is is a re d u c tio n o f th e ru n t i m e b y _ _ _ _ _ _
% th r o u g h th e u s a g e o f fu ll b u ffe rin g in s te a d o f n e s te d s e le c t s .
A n s w e r :
C o n t i n u e d o n n e x t p a g e
6 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 74/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ S E C _ D B _ C O N _ S 1 )
R E P O R T y h a 4 0 0 _ s e c _ d b _ c o n _ s 1 .
. . .
* D a t a b a s e c o n n e c t i o n
C O N S T A N T S c _ c o n T Y P E s t r i n g V A L U E ' S F L I G H T ' .
. . .
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l s _ s c u s t o m T Y P E s c u s t o m ,
l s _ s b o o k T Y P E s b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T * F R O M s c u s t o m
C O N N E C T I O N ( c _ c o n )
I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 6 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 75/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
S E L E C T * F R O M s b o o k
C O N N E C T I O N ( c _ c o n )
I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d
A N D c a n c e l l e d = s p a c e .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r _ d a t
l v _ c o u n t = l v _ c o u n t + 1 .
E N D S E L E C T .
I F l v _ c o u n t < > 0 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
E N D I F .
E N D S E L E C T .
S O R T c t _ c u s t o m e r s B Y i d .
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
E N D O F l t y _ s _ c u s t .
C o n t i n u e d o n n e x t p a g e
6 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 76/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
T Y P E S : B E G I N O F l t y _ s _ b o o k ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l s _ s c u s t o m T Y P E l t y _ s _ c u s t ,
l s _ s b o o k T Y P E l t y _ s _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
C O N N E C T I O N ( c _ c o n )
I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - d a y s _ a h e a d .
C L E A R l v _ c o u n t .
S E L E C T f l d a t e o r d e r _ d a t e
F R O M s b o o k
C O N N E C T I O N ( c _ c o n )
I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d
A N D c a n c e l l e d = s p a c e .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + ( l s _ s b o o k - f l d a t e - l s _ s b o o k - o r d e r
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 6 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 77/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
l v _ c o u n t = l v _ c o u n t + 1 .
E N D S E L E C T .
E N D I F .
E N D S E L E C T .
S O R T c t _ c u s t o m e r s B Y i d .
E N D F O R M . "
6 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 78/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : T a b le s in S A P H A N A S tu d io
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• U n d e rs ta n d S c h e m a ta a n d T a b le s in S A P H A N A S t u d i o
• A n a ly z e th e D e n itio n o f T a b le s in S A P H A N A S t u d i o
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 6 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 79/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
L e s s o n : P e r f o r m a n c e R u l e s a n d G u i d e li n e s f o r S A P
H A N A
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• U n d e r s t a n d t h e p e r f o r m a n c e r u l e s a n d g u i d e l i n e s f o r H A N A
B u s i n e s s E x a m p l e
F ig u r e 3 0 : C o n c lu s io n I
F ig u r e 3 1 : C o n c lu s io n I I
7 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 80/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : P e r fo r m a n c e R u le s a n d G u id e lin e s fo r S A P H A N A
F ig u r e 3 2 : C o n c lu s io n I I I
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 7 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 81/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 2 : T a k in g A B A P to H A N A H A 4 0 0
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• U n d e r s t a n d t h e p e r f o r m a n c e r u l e s a n d g u i d e l i n e s f o r H A N A
7 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 82/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 U n it S u m m a r y
U n it S u m m a r y
Y o u s h o u ld n o w b e a b l e t o :
• U n d e r s t a n d t h e R u n t i m e A n a l y s i s ( S E 3 0 )
• U n d e r s t a n d t h e A B A P T r a c e ( S A T )
• U n d e r s t a n d t h e C o d e I n s p e c t o r ( S C I )
• U n d e r s t a n d t h e S Q L T r a c e ( S T 0 5 )
• D e s c rib e h o w to a c c e s s th e S A P H A N A D a t a b a s e b y u s i n g O p e n S Q L a n d a
s e c o n d a r y d a t a b a s e c o n n e c t i o n
• U n d e rs ta n d S c h e m a ta a n d T a b le s in S A P H A N A S t u d i o
• A n a ly z e th e D e n itio n o f T a b le s in S A P H A N A S t u d i o
• U n d e r s t a n d t h e p e r f o r m a n c e r u l e s a n d g u i d e l i n e s f o r H A N A
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 7 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 83/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it S u m m a r y H A 4 0 0
7 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 84/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 85/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 86/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
Im p le m e n tin g A B A P
U n i t 3
R e p o r t o n H A N A
U s in g A D B C
U n i t O v e r v i e w
T h i s U n i t i s d e s i g n e d t o t e a c h t h e f o l l o w i n g t o p i c s :
• W h y a r e w e u s in g n a tiv e S Q L ?
• A B A P D a t a b a s e C o n n e c t i v i t y ( A D B C )
• N a tiv e S Q L S y n ta x
U n i t O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s u n i t , y o u w i l l b e a b l e t o :
• D e s c r i b e t h e u s e o f n a t i v e S Q L i n t h e c o n te x t o f S A P H A N A
• U n d e r s t a n d A B A P D a t a b a s e C o n n e c t i v it y ( A D B C )
• U s e A D B C t o e x e c u t e n a t i v e S Q L s t a t e m e n ts
• U n d e r s t a n d t h e m a i n d i f f e r e n c e b e t w e e n n a t i v e S Q L S y n t a x a n d O p e n S Q L
S y n t a x
• W r i t e s y n t a c t i c a l l y c o r r e c t N a t i v e S Q L S t a t e m e n t s
U n i t C o n t e n t s
L e s s o n : W h y a r e w e u s i n g n a t i v e S Q L ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 6
L e s s o n : A B A P D a t a b a s e C o n n e c t i v i t y ( A D B C ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 9
L e s s o n : N a t i v e S Q L S y n t a x . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 3
E x e r c is e 6 : U s e A B A P D a ta b a s e C o n n e c t iv it y ( A D B C ) t o is s u e a n a t i v e
S Q L S E L E C T s ta te m e n t.. ... .. . .. ... .. ... .. ... ... .. ... ... .. ... .. . . . . . . . . . . . 8 5
E x e r c is e 7 : Is s u e a n a t iv e S Q L Jo in v ia A
B A P D a ta b a s e C o n n e c t iv it y
(A D B C )... .............. ........... .......... .. ................... .. . . . . . . . . . . . 9 1
E x e r c is e 8 : M a k e u s e o f n a tiv e S Q L to ac c e s s d a ta b a s e s p e c i c
fu n c tio n s . .............. ........... .......... ..................... .. . . . . . . . . . . 1 0 1
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 7 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 87/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
L e s s o n : W h y a r e w e u s in g n a t iv e S Q L ?
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• D e s c r i b e t h e u s e o f n a t i v e S Q L i n t h e c o n t e x t o f S A P H A N A
B u s i n e s s E x a m p l e
F ig u r e 3 3 : R e m in d e r : S Q L In A N u t s h e ll
F ig u r e 3 4 : O p e n S Q L in A B A P
7 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 88/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : W h y a r e w e u s in g n a tiv e S Q L ?
F i g u r e 3 5 : E x a m p l e : T r a n s la t i o n o f O p e n S Q L t o N a t i v e S Q L
F ig u r e 3 6 : R e s tr ic tio n s o f O p e n S Q L
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 7 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 89/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• D e s c r i b e t h e u s e o f n a t i v e S Q L i n t h e c o n t e x t o f S A P H A N A
7 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 90/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : A B A P D a ta b a s e C o n n e c tiv ity (A D B C )
L e s s o n : A B A P D a t a b a s e C o n n e c t iv i t y ( A D B C )
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• U n d e r s t a n d A B A P D a t a b a s e C o n n e c t i v it y ( A D B C )
• U s e A D B C t o e x e c u t e n a t i v e S Q L s t a t e m e n ts
B u s i n e s s E x a m p l e
F i g u r e 3 7 : B a s i c F e a t u r e s o f A D B C
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 7 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 91/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
F i g u r e 3 8 : S e q u e n c e f o r R e a d i n g D a t a w i t h A D B C
F ig u r e 3 9 : C o d in g E x a m p le : A B A P D a t a b a s e C o n n e c t i v it y ( A D B C )
8 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 92/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : A B A P D a ta b a s e C o n n e c tiv ity (A D B C )
F i g u r e 4 0 : A D B C : I m p o r t a n t T h i n g s t o K e e p i n M i n d
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 8 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 93/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• U n d e r s t a n d A B A P D a t a b a s e C o n n e c t i v it y ( A D B C )
• U s e A D B C t o e x e c u te n a t i v e S Q L s t a t e m e n t s
8 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 94/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
L e s s o n : N a t i v e S Q L S y n t a x
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• U n d e r s t a n d t h e m a i n d i f f e r e n c e b e t w e e n n a t i v e S Q L S y n t a x a n d O p e n S Q L
S y n t a x
• W r i t e s y n t a c t i c a l l y c o r r e c t N a t i v e S Q L S t a t e m e n t s
B u s i n e s s E x a m p l e
F i g u r e 4 1 : N a t i v e S Q L i n A B A P
F ig u r e 4 2 : N a t iv e S Q L S y n ta x → O p e n S Q L S y n ta x
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 8 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 95/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
F ig u r e 4 3 : E x a m p le 1 : O p e n S Q L S y n t a x a n d N a tiv e S Q L S y n t a x
F ig u r e 4 4 : E x a m p le 2 : J o in s in O p e n S Q L a n d N a tiv e S Q L
8 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 96/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
E x e r c is e 6 : U s e A B A P D a t a b a s e
CS E o nL nE e C c T t i sv t i ta y t e ( mA D e nB t C ) t o i s s u e a n a t i v e S Q L
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• u s e A B A P D a ta b a s e C o n n e c tiv ity ( A D B C ) t o r e a d d a ta f r o m a D a t a b a s e
• u n d e r s t a n d t h e m a i n d i f f e r e n c e s b e t w e e n t h e s y n t a x o f n a t i v e S Q L a n d o p e n
S Q L
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ A D B C _ T 1
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ A D B C _ S 1
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ A D B C _ T 1 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ A D B C _ 1 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : U s e A D B C to a c c e s s S A P H A N A v ia n a t iv e S Q L
E d it y o u r p ro g ra m . C o p y th e so u rc e c o d e o f su b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b ro u tin e g e t _ d a ta _ s o lu tio n . I n s u b ro u tin e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e o p e n
S Q L S E L E C T o n S C U S T O M w ith a n a tiv e S Q L S E L E C T i s s u e d b y m e a n s o f
A D B C . M a k e su re y o u re a d e x a c tly th e s a m e d a t a .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c r e a t e a n i n s t a n c e o f c l a s s
C L _ S Q L _ C O N N E C T I O N .
H i n t : U s e p u b l i c s t a t i c m e t h o d g e t _ c o n n e c t i o n o f t h a t c l a s s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 8 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 97/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
3 . C r e a t e a n i n s t a n c e o f c la s s C L _ S Q L _ S T A T E M E N T , h a n d i n g o v e r t h e
i n s t a n c e o f C L _ S Q L _ C O N N E C T I O N t o t h e c o n s t r u c t o r
4 . D e n e a s tr in g v a r ia b le ( s u g g e s te d n a m e : l v _ s q l ) a n d l l i t w i t h t h e
n a tiv e S Q L s y n ta x th a t c o rre sp o n d s t o t h e o p e n S Q L s t a t e m e n t f o u n d i n
th e te m p la te . U s e e ith e r a c la s s ic a l C O N C A T E N A T E o r a m o r e m o d e r n
s trin g - te m p la te /- e x p r e s s io n a p p r o a c h .
C a u t i o n : M a k e s u r e t o u s e “ , ” a s s e p a r a t o r i n t h e e l d l i s t a n d t h e
O R D E R B Y - a d d it i o n a n d d o n ’ t f o r g e t t o a d d a W H E R E - c l a u s e f o r
t h e c l i e n t .
5 . C r e a t e a n i n s t a n c e o f C L _ S Q L _ R E S U L T _ S E T b y e x e c u t i n g t h e q u e r y .
6 . D e n e a r e f e r e n c e v a r i a b l e o f t y p e R E F T O D A T A , l e t i t p o i n t t o
t h e t a r g e t d a t a o b j e c t a n d h a n d t h i s r e f e r e n c e o v e r t o t h e i n s t a n c e o f
C L _ S Q L _ R E S U L T _ S E T .
H i n t : U s e m e t h o d s e t _ p a r a m _ t a b l e o f c l a s s C L _ S Q L _ R E -
S U L T _ S E T .
7 . R e t r i e v e t h e r e s u l t a n d c l o s e t h e q u e r y .
8 . I m p l e m e n t a n e x c e p t i o n h a n d l i n g f o r a l l c l a s s b a s e d e x c e p t i o n s t h a t m i g h t b e
r a i s e d b y t h e c a l l e d A D B C - m e t h o d s .
9 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
8 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 98/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
S o lu tio n 6 : U s e A B A P D a t a b a s e
CS E o nL nE e C c T t i sv t i ta y t e ( mA D e nB t C ) t o i s s u e a n a t i v e S Q L
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ A D B C _ T 1 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ A D B C _ 1 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : U s e A D B C to a c c e s s S A P H A N A v ia n a t iv e S Q L
E d it y o u r p ro g ra m . C o p y th e so u rc e c o d e o f su b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b ro u tin e g e t _ d a ta _ s o lu tio n . I n s u b ro u tin e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e o p e n
S Q L S E L E C T o n S C U S T O M w ith a n a tiv e S Q L S E L E C T i s s u e d b y m e a n s o f
A D B C . M a k e su re y o u re a d e x a c tly th e s a m e d a t a .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c r e a t e a n i n s t a n c e o f c l a s s
C L _ S Q L _ C O N N E C T I O N .
H i n t : U s e p u b l i c s t a t i c m e t h o d g e t _ c o n n e c t i o n o f t h a t c l a s s .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
3 . C r e a t e a n i n s t a n c e o f c la s s C L _ S Q L _ S T A T E M E N T , h a n d i n g o v e r t h e
i n s t a n c e o f C L _ S Q L _ C O N N E C T I O N t o t h e c o n s t r u c t o r
a ) S e e s o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n .
4 . D e n e a s trin g v a ria b le (s u g g e s te d n a m e : l v _ s q l ) a n d l l i t w i t h t h e
n a tiv e S Q L s y n ta x th a t c o rre sp o n d s t o t h e o p e n S Q L s t a t e m e n t f o u n d i n
th e te m p la te . U s e e ith e r a c la s s ic a l C O N C A T E N A T E o r a m o r e m o d e r n
s tr in g - te m p la te / - e x p r e s s io n a p p ro a c h .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 8 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 99/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
C a u t i o n : M a k e s u r e t o u s e “ , ” a s s e p a r a t o r i n t h e e l d l i s t a n d t h e
Ot h R e D c l E i e R n t B . Y - a d d i t i o n a n d d o n ’ t f o r g e t t o a d d a W H E R E - c l a u s e f o r
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . C r e a t e a n i n s t a n c e o f C L _ S Q L _ R E S U L T _ S E T b y e x e c u t i n g t h e q u e r y .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
6 . D e n e a r e f e r e n c e v a r i a b l e o f t y p e R E F T O D A T A , l e t i t p o i n t t o
t h e t a r g e t d a t a o b j e c t a n d h a n d t h i s r e f e r e n c e o v e r t o t h e i n s t a n c e o f
C L _ S Q L _ R E S U L T _ S E T .
H i n t : U s e m e t h o d s e t _ p a r a m _ t a b l e o f c l a s s C L _ S Q L _ R E -
S U L T _ S E T .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
7 . R e t r i e v e t h e r e s u l t a n d c l o s e t h e q u e r y .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
8 . I m p l e m e n t a n e x c e p t i o n h a n d l i n g f o r a l l c l a s s b a s e d e x c e p t i o n s t h a t m i g h t b e
r a i s e d b y t h e c a l l e d A D B C - m e t h o d s .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
9 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ A D B C _ S 1 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
C o n t i n u e d o n n e x t p a g e
8 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 100/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
C O N N E C T I O N ( c _ c o n )
I N T O T A B L E c t _ c u s t o m e r s
O R D E R B Y i d .
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* A D B C O b j e c t s a n d V a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E x c e p t i o n H a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
* S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
* F R O M s c u s t o m
* C O N N E C T I O N s f l i g h t
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 8 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 101/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
* I N T O T A B L E c t _ c u s t o m e r s .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
C O N C A T E N A T E ` S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y `
` F R O M S F L I G H T . S C U S T O M `
` W H E R E M A N D T = `
s y - m a n d t
` O R D E R B Y M A N D T , I D `
I N T O l v _ s q l
S E P A R A T E D B Y s p a c e .
* A l t e r n a t i v e : U s e s t r i n g t e m p l a t e s a n d s t r i n g e x p r e s s i o n s
* l v _ s q l = | S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y | & &
* | F R O M S F L I G H T . S C U S T O M | & &
* | W H E R E M A N D T = { s y - m a n d t } | & &
* | O R D E R B Y M A N D T , I D | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F c t _ c u s t o m e r s I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
9 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 102/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
E x e r c is e 7 : I s s u e a n a t i v e S Q L J o i n v ia
A B A P D a t a b a s e C o n n e c t i v i t y ( A D B C )
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• u s e A B A P D a ta b a s e C o n n e c tiv ity ( A D B C ) t o r e a d d a ta f r o m a d a t a b a s e
• u n d e r s t a n d t h e s y n t a x o f j o i n s i n n a t i v e S Q L
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ A D B C _ T 2
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ A D B C _ S 2
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ A D B C _ T 2 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ A D B C _ 2 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : U s e A D B C t o s e n d a n a t iv e S Q L - S E L E C T w it h
a jo in t o t h e S A P H A N A d a t a b a s e
E d it y o u r p ro g ra m . C o p y th e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b ro u tin e g e t _ d a ta _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e o p e n
S Q L S E L E C T o n S C U S T O M a n d S B O O K w i t h a n a t i v e S Q L S E L E C T i s s u e d b y
m e a n s o f A D B C . M a k e su re y o u r e a d e x a c t l y t h e s a m e d a t a .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 9 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 103/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c r e a t e a n i n s t a n c e o f c l a s s C L _ S Q L _ C O N -
N E C T I O N . C r e a t e a n i n s t a n c e o f c l a s s C L _ S Q L _ S T A T E M E N T , h a n d i n g
o v e r th e in s ta n c e o f C L _ S Q L _ C O N N E C T IO N t o t h e c o n s t r u c t o r
H i n t : A s o f N e t w e a v e r 7 . 0 2 , y o u m a y c h a i n t h e s e t w o m e t h o d s
t o g e t h e r , t h u s o m i t t i n g t h e r e f e r e n c e v a r i a b l e f o r t h e c o n n e c t i o n
o b j e c t .
3 . D e n e a s tr in g v a r ia b le ( s u g g e s te d n a m e : l v _ s q l ) a n d l l i t w i t h t h e
n a tiv e S Q L s y n ta x th a t c o rre sp o n d s t o t h e o p e n S Q L s t a t e m e n t f o u n d i n
th e te m p la te . U s e e ith e r a c la s s ic a l C O N C A T E N A T E o r a m o r e m o d e r n
s trin g - te m p la te /- e x p r e s s io n a p p r o a c h .
C a u t i o n : M a k e s u r e t o u s e “ . ” i n s t e a d o f “ ~ ” a s e l d s e l e c t o r .
4 . E x e c u t e t h e q u e r y , a s s i g n t h e t a r g e t d a t a o b j e c t , r e t r i e v e t h e d a t a a n d c l o s e
t h e q u e r y .
H i n t : C h e c k t h e d e n i t i o n o f t h e t a r g e t d a t a o b j e c t c a r e f u l l y .
5 . W h a t d o y o u h a v e t o c h a n g e t o m a k e t h e d a t a o b je c t w o r k a s t a r g e t f o r
A D B C ?
6 . I m p l e m e n t a n e x c e p t i o n h a n d l i n g f o r a l l c l a s s b a s e d e x c e p t i o n s t h a t m i g h t b e
r a i s e d b y t h e c a l l e d A D B C - m e t h o d s .
7 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
9 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 104/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
S o lu t io n 7 : I s s u e a n a t i v e S Q L J o i n v ia
A B A P D a t a b a s e C o n n e c t i v i t y ( A D B C )
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ A D B C _ T 2 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ A D B C _ 2 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : U s e A D B C t o s e n d a n a t iv e S Q L - S E L E C T w it h
a jo in t o t h e S A P H A N A d a t a b a s e
E d it y o u r p ro g ra m . C o p y th e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b ro u tin e g e t _ d a ta _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e o p e n
S Q L S E L E C T o n S C U S T O M a n d S B O O K w i t h a n a t i v e S Q L S E L E C T i s s u e d b y
m e a n s o f A D B C . M a k e su re y o u r e a d e x a c t l y t h e s a m e d a t a .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c r e a t e a n i n s t a n c e o f c l a s s C L _ S Q L _ C O N -
N E C T I O N . C r e a t e a n i n s t a n c e o f c l a s s C L _ S Q L _ S T A T E M E N T , h a n d i n g
o v e r t h e i n s t a n c e o f C L _ S Q L _ C O N N E C T I O N t o t h e c o n s t r u c t o r
H i n t : A s o f N e t w e a v e r 7 . 0 2 , y o u m a y c h a i n t h e s e t w o m e t h o d s
t o g e t h e r , t h u s o m i t t i n g t h e r e f e r e n c e v a r i a b l e f o r t h e c o n n e c t i o n
o b j e c t .
a ) S e e s o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n .
3 . D e n e a s t r i n g v a r i a b l e ( s u g g e s t e d n a m e : l v _ s q l ) a n d l l i t w i t h t h e
n a tiv e S Q L s y n t a x t h a t c o r r e s p o n d s t o t h e o p e n S Q L s t a t e m e n t f o u n d i n
th e te m p l a t e . U s e e i t h e r a c l a s s i c a l C O N C A T E N A T E o r a m o r e m o d e r n
s tr in g - t e m p l a t e / - e x p r e s s i o n a p p r o a c h .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 9 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 105/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
C a u t i o n : M a k e s u r e t o u s e “ . ” i n s t e a d o f “ ~ ” a s e l d s e l e c t o r .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
4 . E x e c u t e t h e q u e r y , a s s i g n t h e t a r g e t d a t a o b j e c t , r e t r i e v e t h e d a t a a n d c l o s e
t h e q u e r y .
H i n t : C h e c k t h e d e n i t i o n o f t h e t a r g e t d a t a o b j e c t c a r e f u l l y .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . W h a t d o y o u h a v e t o c h a n g e t o m a k e t h e d a t a o b je c t w o r k a s t a r g e t f o r
A D B C ?
A n s w e r : S o r t e d t a b l e s a s t a r g e t s a r e n o t s u p p o r t e d b y A D B C .
6 . I m p l e m e n t a n e x c e p t i o n h a n d l i n g f o r a l l c l a s s b a s e d e x c e p t i o n s t h a t m i g h t b e
r a i s e d b y t h e c a l l e d A D B C - m e t h o d s .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
7 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ A D B C _ S 2 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t _ b o o k ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
C o n t i n u e d o n n e x t p a g e
9 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 106/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ c u s t _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l t _ c u s t _ b o o k T Y P E S O R T E D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d ,
l s _ c u s t _ b o o k T Y P E l t y _ s _ c u s t _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T c ~ i d c ~ n a m e c ~ p o s t c o d e c ~ c i t y c ~ c o u n t r y b ~ f l d a t e b ~ o r d e r _ d a t e
F R O M s c u s t o m A S c I N N E R J O I N s b o o k A S b
O N c ~ i d = b ~ c u s t o m i d
C O N N E C T I O N ( c _ c o n )
I N T O T A B L E l t _ c u s t _ b o o k
W H E R E b ~ c a n c e l l e d = s p a c e
O R D E R B Y c ~ i d .
L O O P A T l t _ c u s t _ b o o k I N T O l s _ c u s t _ b o o k .
I F s y - t a b i x = 1 .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 9 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 107/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
C L E A R l s _ c u s t o m e r .
C L E A R l v _ c o u n t .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
E N D I F .
l v _ c o u n t = l v _ c o u n t + 1 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + l s _ c u s t _ b o o k - f l d a t e - l s _ c u s t _ b o o k - o r d e r
E N D L O O P .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
* S O R T c t _ c u s t o m e r s B Y i d . " a l r e a d y s o r t e d
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t _ b o o k ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ c u s t _ b o o k .
* W o r k A r e a f o r R e s u l t
C o n t i n u e d o n n e x t p a g e
9 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 108/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
* D A T A : l t _ c u s t _ b o o k T Y P E S O R T E D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d , " s o r
D A T A : l t _ c u s t _ b o o k T Y P E S T A N D A R D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d ,
l s _ c u s t _ b o o k T Y P E l t y _ s _ c u s t _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
* S E L E C T c ~ i d c ~ n a m e c ~ p o s t c o d e c ~ c i t y c ~ c o u n t r y b ~ f l d a t e b ~ o r d e r _ d a t e
* F R O M s c u s t o m A S c I N N E R J O I N s b o o k A S b
* O N c ~ i d = b ~ c u s t o m i d
* C O N N E C T I O N ( c _ c o n )
* I N T O T A B L E l t _ c u s t _ b o o k
* W H E R E b ~ c a n c e l l e d = s p a c e .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n a n d C r e a t e s t a t e m e n t o b j e c t
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* o p t i o n a l a s o f N W 7 . 0 2
*
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 9 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 109/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
* C R E A T E O B J E C T l o _ s q l
* E X P O R T I N G
* c o n _ r e f = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* c r e a t e S Q L s t a t e m e n t
C O N C A T E N A T E ` S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y , B . F L D A T E , B . O R D E R _ D A T E
` F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B `
` O N C . M A N D T = B . M A N D T `
` A N D C . I D = B . C U S T O M I D `
` W H E R E C . M A N D T = `
s y - m a n d t
` A N D B . C A N C E L L E D = ' ' `
` O R D E R B Y C . M A N D T , C . I D `
I N T O l v _ s q l
S E P A R A T E D B Y s p a c e .
* A l t e r n a t i v e : U s e s t r i n g t e m p l a t e s a n d s t r i n g e x p r e s s i o n s
* l v _ s q l = | S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y | & &
* | F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B | & &
* | O N C . M A N D T = B . M A N D T A N D C . I D = B . C U S T O M I D | & &
* | W H E R E C . M A N D T = { s y - m a n d t } | & &
* | A N D B . C A N C E L L E D = { S P A C E } | & &
* | O R D E R B Y C . M A N D T , C . I D | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F l t _ c u s t _ b o o k I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
S O R T l t _ c u s t _ b o o k B Y i d .
L O O P A T l t _ c u s t _ b o o k I N T O l s _ c u s t _ b o o k .
C o n t i n u e d o n n e x t p a g e
9 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 110/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
I F s y - t a b i x = 1 .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
C L E A R l s _ c u s t o m e r .
C L E A R l v _ c o u n t .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
E N D I F .
l v _ c o u n t = l v _ c o u n t + 1 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + l s _ c u s t _ b o o k - f l d a t e - l s _ c u s t _ b o o k - o
E N D L O O P .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t .
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
* S O R T c t _ c u s t o m e r s B Y i d . " a l r e a d y s o r t e d
E N D F O R M . "
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 9 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 111/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
1 0 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 112/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
E x e r c is e 8 : M a k e u s e o f n a t i v e S Q L t o
a c c e s s d a t a b a s e s p e c i c f u n c t i o n s
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• u s e A B A P D a ta b a s e C o n n e c tiv ity ( A D B C ) t o r e a d d a ta f r o m a d a t a b a s e
• u n d e r s t a n d t h e s y n t a x o f n a t i v e S Q L
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ A D B C _ T 3
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ A D B C _ S 3
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ A D B C _ T 3 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ A D B C _ 3 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : U s e A D B C a n d n a t iv e S Q L t o r e p la c e t h e
c o m p l e t e d a t a r e t r i e v a l b y j u s t o n e S E L E C T
E d it y o u r p ro g ra m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b ro u t i n e g e t _ d a t a _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I m p l e m e n t a
n a tiv e S Q L S E L E C T t h a t l l s i n t e r n a l t a b l e c t _ c u s t o m e r s d i r e c t l y w i t h o u t a n y
f u r th e r p r o c e s s in g . M a k e u s e o f t h e f a c t t h a t w i t h i n t h e e l d l i s t o f n a t i v e S Q L
S E L E C T s c a lc u la t i o n s a r e p o s s i b l e . A l s o u s e a g g r e g a t i o n a n d o r d e r i n g t e c h n i q u e s
o f S Q L . M a k e s u r e y o u r e a d e x a c t l y t h e s a m e d a t a .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 0 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 113/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c h a n g e t h e n a t i v e S Q L S t a t e m e n t .
E l i m i n a t e e ld s B . O R D E R _ D A T E a n d B . F L D A T E f r o m t h e e ld l i s t a n d
re p la c e th e m b y t h e a g g r e g a t e d d i f f e r e n c e .
H i n t : T h e c o r r e c t s y n t a x
i s A V G (
D A Y S _ B E T W E E N ( B . O R D E R _ D A T E , B . F L D A T E ) ) A S
D A Y S _ A H E A D
3 . I n th e n a tiv e S Q L S y n ta x , a d d a G R O U P B Y a d d it i o n t h a t l i s t s t h e c l i e n t
a n d a l l e l d s f o u n d i n t h e e l d l i s t .
4 . R e p l a c e t a r g e t d a t a o b j e c t l t _ c u s t _ b o o k w i t h c t _ c u s t o m e r s .
5 . R e m o v e th e n o w s u p e r u o u s l o o p o v e r l t _ c u s t _ b o o k w i t h t h e c a l c u l a t i o n
a n d a g g r e g a t i o n .
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
1 0 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 114/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
S o l u t i o n 8 : M a k e u s e o f n a t iv e S Q L t o
a c c e s s d a t a b a s e s p e c i c f u n c t i o n s
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ A D B C _ T 3 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ A D B C _ 3 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : U s e A D B C a n d n a t iv e S Q L t o r e p la c e t h e
c o m p l e t e d a t a r e t r i e v a l b y j u s t o n e S E L E C T
E d it y o u r p ro g ra m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b ro u t i n e g e t _ d a t a _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I m p l e m e n t a
n a tiv e S Q L S E L E C T t h a t l l s i n t e r n a l t a b l e c t _ c u s t o m e r s d i r e c t l y w i t h o u t a n y
f u r th e r p r o c e s s in g . M a k e u s e o f t h e f a c t t h a t w i t h i n t h e e l d l i s t o f n a t i v e S Q L
S E L E C T s c a lc u la tio n s a r e p o s s i b l e . A l s o u s e a g g r e g a t i o n a n d o r d e r i n g t e c h n i q u e s
o f S Q L . M a k e su re y o u r e a d e x a c t l y t h e s a m e d a t a .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c h a n g e t h e n a t i v e S Q L S t a t e m e n t .
E l i m i n a t e e ld s B . O R D E R _ D A T E a n d B . F L D A T E f r o m t h e e ld l i s t a n d
r e p l a c e t h e m b y t h e a g g r e g a t e d d i f f e r e n c e .
H i n t : T h e c o r r e c t s y n t a x
i s A V G (
D A Y S _ B E T W E E N ( B . O R D E R _ D A T E , B . F L D A T E ) ) A S
D A Y S _ A H E A D
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
3 . I n th e n a tiv e S Q L S y n ta x , a d d a G R O U P B Y a d d it i o n t h a t l i s t s t h e c l i e n t
a n d a l l e l d s f o u n d i n t h e e l d l i s t .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 0 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 115/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ A D B C _ S 3 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t _ b o o k ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ c u s t _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
* D A T A : l t _ c u s t _ b o o k T Y P E S O R T E D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d , " s o r e t e d
C o n t i n u e d o n n e x t p a g e
1 0 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 116/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
D A T A : l t _ c u s t _ b o o k T Y P E S T A N D A R D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d ,
l s _ c u s t _ b o o k T Y P E l t y _ s _ c u s t _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
* S E L E C T c ~ i d c ~ n a m e c ~ p o s t c o d e c ~ c i t y c ~ c o u n t r y b ~ f l d a t e b ~ o r d e r _ d a t e
* F R O M s c u s t o m A S c I N N E R J O I N s b o o k A S b
* O N c ~ i d = b ~ c u s t o m i d
* C O N N E C T I O N s f l i g h t
* I N T O T A B L E l t _ c u s t _ b o o k
* W H E R E b ~ c a n c e l l e d = s p a c e .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
C O N C A T E N A T E ` S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y , B . F L D A T E , B . O R D E R _ D
` F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B `
` O N C . M A N D T = B . M A N D T `
` A N D C . I D = B . C U S T O M I D `
` W H E R E C . M A N D T = `
s y - m a n d t
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 0 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 117/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
I N T O l v _ s q l
S E P A R A T E D B Y s p a c e .
* A l t e r n a t i v e : U s e s t r i n g t e m p l a t e s a n d s t r i n g e x p r e s s i o n s
* l v _ s q l = | S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y | & &
* | F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B | & &
* | O N C . M A N D T = B . M A N D T A N D C . I D = B . C U S T O M I D | & &
* | W H E R E C . M A N D T = { s y - m a n d t } | & &
* | A N D B . C A N C E L L E D = { S P A C E } | & &
* | O R D E R B Y C . M A N D T , C . I D | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F l t _ c u s t _ b o o k I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
S O R T l t _ c u s t _ b o o k B Y i d .
L O O P A T l t _ c u s t _ b o o k I N T O l s _ c u s t _ b o o k .
I F s y - t a b i x = 1 .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
l s _ c u s t o m e r - d a y s _ a h e a d = r o u n d ( v a l = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t d e c = 2 m o d e = c
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
C L E A R l s _ c u s t o m e r .
C o n t i n u e d o n n e x t p a g e
1 0 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 118/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
C L E A R l v _ c o u n t .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
E N D I F .
l v _ c o u n t = l v _ c o u n t + 1 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + l s _ c u s t _ b o o k - f l d a t e - l s _ c u s t _ b o o k - o
E N D L O O P .
l s _ c u s t o m e r - d a y s _ a h e a d = r o u n d ( v a l = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t d e c = 2 m o d e = c
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
* S O R T c t _ c u s t o m e r s B Y i d . " a l r e a d y s o r t e d
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* * T y p e s f o r t a r g e t f i e l d s
*
* T Y P E S : B E G I N O F l t y _ s _ c u s t _ b o o k ,
* i d T Y P E s c u s t o m - i d ,
* n a m e T Y P E s c u s t o m - n a m e ,
* p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
* c i t y T Y P E s c u s t o m - c i t y ,
* c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
* f l d a t e T Y P E s b o o k - f l d a t e ,
* o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
* E N D O F l t y _ s _ c u s t _ b o o k .
*
* * W o r k A r e a f o r R e s u l t
* D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 0 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 119/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
*
*
* * T a r g e t s f o r S e l e c t
* D A T A : l t _ c u s t _ b o o k T Y P E S T A N D A R D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d ,
* l s _ c u s t _ b o o k T Y P E l t y _ s _ c u s t _ b o o k .
*
* * h e l p v a r i a b l e s
* D A T A l v _ c o u n t T Y P E i .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
C O N C A T E N A T E ` S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y , A V G ( D A Y S _ B E T W E E N ( B . O R D
` F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B `
` O N C . M A N D T = B . M A N D T `
` A N D C . I D = B . C U S T O M I D `
` W H E R E C . M A N D T = `
s y - m a n d t
` A N D B . C A N C E L L E D = ' ' `
` G R O U P B Y C . M A N D T , C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y `
` O R D E R B Y C . M A N D T , C . I D `
I N T O l v _ s q l
C o n t i n u e d o n n e x t p a g e
1 0 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 120/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : N a tiv e S Q L S y n ta x
S E P A R A T E D B Y s p a c e .
* A l t e r n a t i v e : U s e s t r i n g t e m p l a t e s a n d s t r i n g e x p r e s s i o n s
* l v _ s q l = | S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y A V G ( D A Y S _ B E T W E E N ( B . O R
* | F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B | & &
* | O N C . M A N D T = B . M A N D T A N D C . I D = B . C U S T O M I D | & &
* | W H E R E C . M A N D T = { s y - m a n d t } | & &
* | A N D B . C A N C E L L E D = { S P A C E } | & &
* | G R O U P B Y C . M A N D T , C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y | & &
* | O R D E R B Y C . M A N D T , C . I D | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
* G E T R E F E R E N C E O F l t _ c u s t _ b o o k I N T O l r _ d a t a .
G E T R E F E R E N C E O F c t _ c u s t o m e r s I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 0 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 121/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 3 : Im p le m e n tin g A B A P R e p o r t o n H A N A U s in g A D B C H A 4 0 0
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• U n d e r s t a n d t h e m a i n d i f f e r e n c e b e t w e e n n a t i v e S Q L S y n t a x a n d O p e n S Q L
S y n t a x
• W r i t e s y n t a c t i c a l l y c o r r e c t N a t i v e S Q L S t a t e m e n t s
1 1 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 122/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 U n it S u m m a r y
U n it S u m m a r y
Y o u s h o u ld n o w b e a b l e t o :
• D e s c r i b e t h e u s e o f n a t i v e S Q L i n t h e c o n te x t o f S A P H A N A
• U n d e r s t a n d A B A P D a t a b a s e C o n n e c t i v it y ( A D B C )
• U s e A D B C t o e x e c u t e n a t i v e S Q L s t a t e m e n ts
• U n d e r s t a n d t h e m a i n d i f f e r e n c e b e t w e e n n a t i v e S Q L S y n t a x a n d O p e n S Q L
S y n t a x
• W r i t e s y n t a c t i c a l l y c o r r e c t N a t i v e S Q L S t a t e m e n t s
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 1 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 123/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it S u m m a r y H A 4 0 0
1 1 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 124/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 125/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 126/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o n s u m in g H A N A V ie w s a n d
U n i t 4
P r o c e d u r e s i n A B A P
U n i t O v e r v i e w
T h i s U n i t i s d e s i g n e d t o t e a c h t h e f o l l o w i n g t o p i c s :
• W o r k i n g w i t h v i e w s i n S A P H A N A S tu d i o
• O v e rv ie w o f d if f e r e n t T y p e s o f S A P H A N A v i e w s
• C o n s u m in g S A P H A N A v ie w s i n A B A P
• C a llin g S A P H A N A p r o c e d u r e s i n A B A P
U n i t O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s u n i t , y o u w i l l b e a b l e t o :
• W o r k w ith v ie w s i n th e S A P H A N A S tu d io
• D e s c r i b e t h e d i f f e r e n t T y p e s o f S A P H A N A v i e w s
• C o n su m e H A N A v ie w s in A B A P
• C a ll H A N A p r o c e d u r e s i n A B A P
U n i t C o n t e n t s
L e s s o n : W o r k in g w it h V ie w s in S A P H A N A S tu d io . .. ..... ... ..... ..... . . . . 1 1 4
L e s s o n : O v e r v ie w o f D iffe r e n t T y p e s o f S A P H A N A V ie w s . ..... ..... . . . . 1 1 9
L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P ... .. ..... ... ..... ..... . . . . 1 2 3
E x e r c is e 9 : A n a ly z e a v ie w d e n e d o n S A P H A N A a n d u s e it in a
n a tiv e S Q L S E L E C T . .. . . .. .. .. .. .. .. .. .. .. .. .. .. .. .. . . .. .. .. .. .. ..
.. .. .. .. 1 2 5
E x e r c is e 1 0 : C a ll a S A P H A N A v ie w w ith a n in p u t p a ra m e te r
in a n a t iv e
S Q L S E L E C T . .. .. .. .. .. . . .. .. .. .. .. .. .. .. .. .. .. .. .. .. . . .. .. .. .. .. ..
.. .. .. .. 1 3 7
L e s s o n : C a l lin g S A P H A N A P ro c e d u r e s in A B A P ..... ... .. .. .. .. ..
.. .. .... 1 4 6
E x e r c is e 1 1 : A n a ly z e a s to re d p ro c e d u re d e n e d o n S A P H A N A a n d
c a ll it in a n a tiv e S Q L s ta te m e n t . . .. .. ... . . ... ... .. .. . .. . . . . .. ... .. . .. .. .. 1 4 9
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 127/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
L e s s o n : W o r k in g w ith V ie w s in S A P H A N A S t u d io
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• W o rk w ith v ie w s in th e S A P H A N A S tu d i o
B u s i n e s s E x a m p l e
F i g u r e 4 5 : S e a r c h F u n c t i o n s – G l o b a l S e a r c h
1 1 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 128/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : W o r k in g w ith V ie w s in S A P H A N A S tu d io
F i g u r e 4 6 : S e a r c h F u n c t i o n s – L o c a l S e a r c h i n C o n t e n t
F i g u r e 4 7 : W o r k i n g w i t h V i e w s – O p e n D e n i t i o n a n d D a t a P r e v ie w
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 1 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 129/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
F ig u r e 4 8 : W o r k in g w it h V i e w s – P r e v ie w o f R a w D a t a
F i g u r e 4 9 : W o r k i n g w i t h V i e w s – A n a l y s i s o f D i s t i n c t V a l u e s
1 1 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 130/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : W o r k in g w ith V ie w s in S A P H A N A S tu d io
F ig u r e 5 0 : W o r k in g w i t h V i e w s – G r a p h i c a l A n a l y s is
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 1 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 131/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• W o rk w ith v ie w s in th e S A P H A N A S tu d i o
1 1 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 132/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O v e r v ie w o f D iffe r e n t T y p e s o f S A P H A N A V ie w s
L e s s o n : O v e r v ie w o f D iffe r e n t T y p e s o f S A P H A N A V ie w s
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• D e s c rib e th e d iffe re n t T y p e s o f S A P H A N A v i e w s
B u s i n e s s E x a m p l e
F i g u r e 5 1 : A t t r i b u t e V i e w
F ig u r e 5 2 : E x a m p le : A ttr ib u te V ie w w i t h R e f e r e n t i a l J o i n
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 1 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 133/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
F i g u r e 5 3 : A n a l y t i c V i e w
F ig u r e 5 4 : E x a m p le : A n a ly tic V ie w w i t h C a l c u l a t e d C o l u m n
F ig u r e 5 5 : E x a m p le : A n a ly tic V ie w w i t h C u r r e n c y C o n v e r s i o n
1 2 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 134/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : O v e r v ie w o f D iffe r e n t T y p e s o f S A P H A N A V ie w s
F i g u r e 5 6 : C a l c u l a t i o n V i e w
F ig u r e 5 7 : E x a m p le : G r a p h i c a l C a lc u la tio n V ie w w i t h A g g r e g a t e d C o l u m n s
a n d F i l t e r
F ig u r e 5 8 : E x a m p le : C a lc u la tio n V i e w b a s e d o n S Q L S c r i p t
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 2 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 135/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• D e s c r ib e th e d if f e r e n t T y p e s o f S A P H A N A v i e w s
1 2 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 136/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• C o n su m e H A N A v ie w s in A B A P
B u s i n e s s E x a m p l e
F ig u r e 5 9 : C o n s u m in g H A N A V ie w – L o g i c a l P i c t u r e
F ig u r e 6 0 : C o n s u m in g H A N A V i e w s – N a tiv e S Q L S y n t a x
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 2 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 137/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
F ig u r e 6 1 : C o n s u m in g H A N A V i e w s w i t h I n p u t P a r a m e t e r s – L o g i c a l V i e w
F ig u r e 6 2 : In p u t P a r a m e te rs in H A N A V i e w s – T h e F a c ts
F ig u r e 6 3 : C o n s u m in g H A N A V i e w s w i t h I n p u t P a r a m e t e r s – N a t i v e S Q L
S y n t a x
1 2 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 138/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
E x e r c is e 9 : A n a ly z e a v ie w d e n e d o n S A P
H A N A a n d u s e it in a n a t iv e S Q L S E L E C T
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• a n a l y z e a n d u n d e r s t a n d v i e w s d e n e d o n S A P H A N A
• u se S A P H A N A v i e w s i n t h e F R O M - c l a u s e o f n a t i v e S Q L S E L E C T s
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ U S E _ H A N A _ V I E W T 1
S o l u t i o n :
R e p o rt Y H A 4 0 0 _ U S E _ H A N A _ V IE W _ S 1
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ H A N A _ V I E W _ T 1 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ H V I E W _ 1 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
T a s k 2 : F in d a n d a n a ly z e a S A P H A N A V ie w
I n th e S A P H A N A S tu d io , s e a rc h fo r a v ie w th a t c o n ta in s th e r e le v a n t in f o r m a t i o n
f ro m ta b le s S C U S T O M a n d S B O O K , in c lu d in g a c a lc u la te d e ld fo r th e n u m b e r
o f d a y s b e tw e en o rd e r d a te a n d i g h t d a te . T h e v ie w s h o u ld n o t p r o v id e a n y
a g g r e g a tio n , y e t. C h e c k a ll re le v a n t p r o p e rtie s o f th e v ie w , d is p la y th e ra w d a t a
a n d d o a little a n a ly s is o f th e v ie w ’s c o n te n t w ith th e d a ta p r e v ie w t o o l .
1 . G o t o t h e S A P H A N A S t u d i o a n d s e a r c h t h e C o n t e n t f o r v ie w s h a v in g
“ d a y s ” i n t h e i r n a m e s .
H i n t : K e e p i n m i n d t h a t S A P H A N A u s e s “ % ” a s w i l d c a r d s y m b o l
( a s c o m m o n i n S Q L ) r a t h e r t h a n t h e “ * ” c h a r a c t e r k n o w n f r o m S A P
G U I s e l e c t i o n s c r e e n s .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 2 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 139/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
2 . T h e l i s t c o n t a i n s t h e f o l l o w i n g v i e w s :
3 . B o t h v i e w s a r e l o c a t e d i n p a c k a g e
4 . A c c o r d i n g t o n a m i n g c o n v e n t i o n s , w h i c h o f t h e v i e w s c a n y o u e x p e c t t o
b e a n a t t r i b u t e v i e w ?
5 . C h o o s e t h e a t t r i b u t e v i e w a n d a n a l y z e i t s d e n i t i o n .
6 . V ie w is b a s e d o n d a ta b a s e
ta b le s a n d . T h e ta b le s a re
j o i n e d b y a jo i n o f c a rd in a lity . T h e
v ie w c o n s is ts o f e ld s fro m th e le ft ta b le , e ld s f r o m t h e
rig h t ta b le a n d 1 c a lc u la te d e ld . T h e c a lc u la te d e ld ’s n a m e i s
. It’s c a lc u la tio n e x p re s sio n re a d s a s f o l l o w s :
T h e v i e w c o n t a i n s o n e l t e r c o n d i t i o n : O n l y s u c h e n t r i e s a r e s e l e c t e d
w h e re th e e ld c o n ta in s th e v a lu e
. T h e v ie w s rs t e l d s a r e k e y e l d s . T h e e l d w i t h n a m e
i s h i d d e n .
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
C o n t i n u e d o n n e x t p a g e
1 2 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 140/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
T a s k 3 : U s e th e S A P H A N A V ie w in a n a t i v e S Q L S e le c t
E d it y o u r p r o g r a m . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ te m p la t e t o
s u b ro u t i n e g e t _ d a t a _ s o l u t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I m p le m e n t a
n a tiv e S Q L S E L E C T t h a t l l s i n t e r n a l t a b l e c t _ c u s t o m e r s d i r e c t l y w ith o u t a n y
f u rth e r p r o c e s s in g . S e le c t f r o m th e v i e w y o u ju s t f o u n d a n d im p l e m e n t t h e
a g g re g a t i o n ( c a l c u l a t i o n o f a v e r a g e ) i n t h e S E L E C T s t a t e m e n t .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c h a n g e t h e n a t i v e S Q L S t a t e m e n t . I n t h e
F R O M - c l a u s e , r e p l a c e t h e jo i n o f t a b l e s S C U S T O M a n d S B O O K w i t h t h e
v i e w y o u ju s t f o u n d .
H i n t : R e m e m b e r t o s t a t e t h e v i e w ’ s n a m e w i t h i t ’ s c o m p l e t e p a t h ,
i . e . _ S Y S _ B I C / < p a c k a g e n a m e > . < s u b p a c k a g e n a m e > . . . / < v i e w
n a m e >
C a u t i o n : N a m e s o n S A P H A N A a r e c a s e s e n s i t i v e . B u t e v e r y t h i n g
n o t i n c l u d e d i n “ ” w i l l b e t r a n s l a t e d t o u p p e r c a s e !
3 . A d ju s t t h e e ld l i s t o f y o u r S Q L s t a t e m e n t t o m a k e t h e e ld n a m e s
c o r r e s p o n d t o t h e e l d n a m e s i n t h e v i e w . D e n e a n a g g r e g a t i o n o f e l d
D A Y S _ A H E A D , u s i n g a g g r e g a t i o n f u n c t i o n A V G ( ) a n d a d d a G R O U P B Y
a d d i t i o n t h a t l i s t s t h e c l i e n t a n d a l l e l d s f r o m t h e e l d l i s t .
4 . R e m o v e e l d C A N C E L L E D f r o m t h e W H E R E - c l a u s e a s t h i s l t e r c o n d i t i o n
i s a l r e a d y p a r t o f t h e v i e w ’ s d e n i t i o n .
5 . R e p l a c e t a r g e t d a t a o b j e c t l t _ c u s t _ b o o k w i t h c t _ c u s t o m e r s .
6 . R e m o v e t h e n o w s u p e r u o u s l o o p o v e r l t _ c u s t _ b o o k w i t h t h e c a l c u l a t i o n
a n d a g g r e g a t i o n .
7 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 2 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 141/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
S o lu tio n 9 : A n a ly z e a v ie w d e n e d o n S A P
H A N A a n d u s e it in a n a t iv e S Q L S E L E C T
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ H A N A _ V I E W _ T 1 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ H V I E W _ 1 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : F in d a n d a n a ly z e a S A P H A N A V ie w
I n th e S A P H A N A S tu d io , s e a rc h fo r a v ie w th a t c o n ta in s th e r e le v a n t in f o r m a t i o n
f ro m ta b le s S C U S T O M a n d S B O O K , in c lu d in g a c a lc u la te d e ld fo r th e n u m b e r
o f d a y s b e tw e en o rd e r d a te a n d i g h t d a te . T h e v ie w s h o u ld n o t p r o v id e a n y
a g g re g a tio n , y e t. C h e c k a ll re le v a n t p r o p e rtie s o f th e v ie w , d is p la y th e ra w d a t a
a n d d o a little a n a ly s is o f th e v ie w ’s c o n te n t w ith th e d a ta p r e v ie w t o o l .
1 . G o to th e S A P H A N A S t u d i o a n d s e a r c h t h e C o n t e n t f o r v ie w s h a v in g
“ d a y s ” i n t h e i r n a m e s .
H i n t : K e e p i n m i n d t h a t S A P H A N A u s e s “ % ” a s w i l d c a r d s y m b o l
( a s c o m m o n i n S Q L ) r a t h e r t h a n t h e “ * ” c h a r a c t e r k n o w n f r o m S A P
G U I s e l e c t i o n s c r e e n s .
a ) I n th e N a v ig a to r w in d o w o n t h e l e f t s i d e , r i g h t - c l i c k o n n o d e C o n t e n t
a n d c h o o s e F i n d .
b ) E n t e r t h e s e a r c h s t r i n g ( e . g . “ % d a y s ” ) .
2 . T h e l i s t c o n t a i n s t h e f o l l o w i n g v i e w s :
A n s w e r :
A T _ D A Y S _ A H E A D
C A _ C U S T _ W I T H _ A V G _ D A Y S _ A H E A D
3 . B o t h v i e w s a r e l o c a t e d i n p a c k a g e
A n s w e r : y h a 4 0 0 . d e m o
C o n t i n u e d o n n e x t p a g e
1 2 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 142/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
4 . A c c o r d i n g t o n a m i n g c o n v e n t i o n s , w h i c h o f t h e v i e w s c a n y o u e x p e c t t o
b e a n a t t r i b u t e v i e w ?
A n s w e r : A T _ D A Y S _ A H E A D , a s A T s t a n d s f o r a t t r i b u t e v i e w .
5 . C h o o s e t h e a t t r i b u t e v i e w a n d a n a l y z e i t s d e n i t i o n .
a ) D o u b l e c l i c k t h e v i e w i n t h e s e a r c h r e s u l t o r c l i c k o n i t a n d c h o o s e O K
.
b ) D o u b l e c l i c k o n D a t a F o u n d a t i o n t o s e e a g r a p h i c a l d i s p l a y o f t h e
d a t a b a s e t a b l e s , t h e j o i n c o n d i t i o n s , t h e e l d s o f t h e o u t p u t a n d t h e i r
o r i g i n . F i l t e r i c o n s i n d i c a t e e l d s w h e r e l t e r s a r e i n p l a c e .
c ) D o u b l e c l i c k o n o n e o f t h e j o i n l i n e s t o s e e t h e j o i n t y p e a n d t h e
c a r d i n a l i t y .
d ) I n t h e o u t p u t - f r a m e o n t h e r i g h t , d o u b l e c l i c k o n t h e c a l c u l a t e d e l d
D A Y S _ A H E A D t o s e e t h e c a l c u l a t i o n r u l e .
e ) D o u b l e c l i c k o n S e m a n t i c s t o s e e a l i s t o f t h e o u t p u t e l d s w i t h t h e i r
v i s i b i l i t y a n d t h e i r c l a s s i c a t i o n a s k e y a t t r i b u t e s o r n o r m a l a t t r i b u t e s .
6 . V i e w A T _ D A Y S _ A H E A D i s b a s e d o n d a t a b a s e t a b l e s S B O O K a n d
S C U S T O M . T h e t a b l e s a r e j o i n e d b y a r e f e r e n t i a l j o i n o f c a r d i n a l i t y n . . 1 . T h e
v i e w c o n s i s t s o f 6 e l d s f r o m t h e l e f t t a b l e , 5 e l d s f r o m t h e r i g h t t a b l e a n d 1
c a l c u l a t e d e l d . T h e c a l c u l a t e d e l d ’ s n a m e i s d a y s _ a h e a d . I t ’ s c a l c u l a t i o n
e x p r e s s i o n r e a d s a s f o l l o w s : d a y s b e t w e e n ( d a t e ( " O R D E R _ D A T E " ) ,
d a t e ( " F L D A T E " ) ) . T h e v i e w c o n t a i n s o n e l t e r c o n d i t i o n : O n l y s u c h e n t r i e s
a r e s e l e c t e d w h e r e t h e e l d C A N C E L L E D c o n t a i n s t h e v a l u e ’ ’ . T h e v i e w s
r s t 5 e ld s a r e k e y e ld s . T h e e ld w i t h n a m e O R D E R _ D A T E i s h i d d e n .
A n s w e r : A T _ D A Y S _ A H E A D , S B O O K , S C U S T O M , r e f e r e n ti a l , n .. 1 , 6 ,
5 , d a y s_ a h e a d , d a y s b e tw e e n (d a te (" O R D E R _ D A T E " ) , d a t e ( " F L D A T E " ) ) ,
C A N C E L L E D , ’ ’, 5 , O R D E R _ D A T E
T a s k 3 : U s e th e S A P H A N A V ie w in a n a t i v e S Q L S e le c t
E d it y o u r p ro g ra m . C o p y th e s o u rc e c o d e o f s u b ro u tin e g e t _ d a t a _ te m p la t e t o
s u b ro u t i n e g e t _ d a ta _ s o lu t i o n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I m p le m e n t a
n a tiv e S Q L S E L E C T th a t l l s i n t e r n a l t a b l e c t _ c u s t o m e r s d i r e c t l y w ith o u t a n y
f u rth e r p r o c e ss in g . S e le c t f r o m th e v i e w y o u ju s t f o u n d a n d im p le m e n t t h e
a g g r e g a t i o n ( c a l c u l a t i o n o f a v e r a g e ) i n t h e S E L E C T s t a t e m e n t .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 2 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 143/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c h a n g e t h e n a t i v e S Q L S t a t e m e n t . I n t h e
F R O M - c l a u s e , r e p l a c e t h e j o i n o f t a b l e s S C U S T O M a n d S B O O K w i t h t h e
v ie w y o u ju s t f o u n d .
H i n t : R e m e m b e r t o s t a t e t h e v i e w ’ s n a m e w i t h i t ’ s c o m p l e t e p a t h ,
i . e . _ S Y S _ B I C / < p a c k a g e n a m e > . < s u b p a c k a g e n a m e > . . . / < v i e w
n a m e >
C a u t i o n : N a m e s o n S A P H A N A a r e c a s e s e n s i t i v e . B u t e v e r y t h i n g
n o t i n c l u d e d i n “ ” w i l l b e t r a n s l a t e d t o u p p e r c a s e !
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
3 . A d ju s t t h e e ld lis t o f y o u r S Q L s ta te m e n t to m a k e th e e ld n a m e s
c o rre sp o n d to th e e ld n a m e s in th e v ie w . D e n e a n a g g r e g a t i o n o f e l d
D A Y S _ A , u sin g
H E A D a g g re g a tio n fu n c tio n A V G ( ) a n d a d d a G R O U P B Y
a d d itio n th a t l is ts th e c lie n t a n d a ll e ld s fro m th e e ld l i s t .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
4 . R e m o v e e l d C A N C E L L E D f r o m t h e W H E R E - c l a u s e a s t h i s l t e r c o n d i t i o n
i s a l r e a d y p a r t o f t h e v i e w ’ s d e n i t i o n .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . R e p l a c e t a r g e t d a t a o b j e c t l t _ c u s t _ b o o k w i t h c t _ c u s t o m e r s .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
6 . R e m o v e t h e n o w s u p e r u o u s l o o p o v e r l t _ c u s t _ b o o k w i t h t h e c a l c u l a t i o n
a n d a g g r e g a t i o n .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
7 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ U S E _ H A N A _ V I E W _ S 1 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
C o n t i n u e d o n n e x t p a g e
1 3 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 144/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
T Y P E S : B E G I N O F l t y _ s _ c u s t _ b o o k ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
f l d a t e T Y P E s b o o k - f l d a t e ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
E N D O F l t y _ s _ c u s t _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l t _ c u s t _ b o o k T Y P E S T A N D A R D T A B L E O F l t y _ s _ c u s t _ b o o k W I T H N O N - U N I Q U E K E Y i d ,
l s _ c u s t _ b o o k T Y P E l t y _ s _ c u s t _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
T R Y .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 3 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 145/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
C O N C A T E N A T E ` S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y , B . F L D A T E , B . O R D E R _ D A T E
` F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B `
` O N C . M A N D T = B . M A N D T `
` A N D C . I D = B . C U S T O M I D `
` W H E R E C . M A N D T = `
s y - m a n d t
` A N D B . C A N C E L L E D = ' ' `
` O R D E R B Y C . M A N D T , C . I D `
I N T O l v _ s q l
S E P A R A T E D B Y s p a c e .
* A l t e r n a t i v e : U s e s t r i n g t e m p l a t e s a n d s t r i n g e x p r e s s i o n s
* l v _ s q l = | S E L E C T C . I D , C . N A M E , C . P O S T C O D E , C . C I T Y , C . C O U N T R Y | & &
* | F R O M S F L I G H T . S C U S T O M A S C I N N E R J O I N S F L I G H T . S B O O K A S B | & &
* | O N C . M A N D T = B . M A N D T A N D C . I D = B . C U S T O M I D | & &
* | W H E R E C . M A N D T = { s y - m a n d t } | & &
* | A N D B . C A N C E L L E D = { S P A C E } | & &
* | O R D E R B Y C . M A N D T , C . I D | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F l t _ c u s t _ b o o k I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
S O R T l t _ c u s t _ b o o k B Y i d .
C o n t i n u e d o n n e x t p a g e
1 3 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 146/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
L O O P A T l t _ c u s t _ b o o k I N T O l s _ c u s t _ b o o k .
I F s y - t a b i x = 1 .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
l s _ c u s t o m e r - d a y s _ a h e a d = r o u n d ( v a l = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t d e c = 2 m o d e
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
C L E A R l s _ c u s t o m e r .
C L E A R l v _ c o u n t .
l s _ c u s t o m e r - i d = l s _ c u s t _ b o o k - i d .
l s _ c u s t o m e r - n a m e = l s _ c u s t _ b o o k - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ c u s t _ b o o k - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ c u s t _ b o o k - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ c u s t _ b o o k - c o u n t r y .
E N D I F .
l v _ c o u n t = l v _ c o u n t + 1 .
l s _ c u s t o m e r - d a y s _ a h e a d = l s _ c u s t o m e r - d a y s _ a h e a d + l s _ c u s t _ b o o k - f l d a t e - l s _ c u s t _ b o o k - o
E N D L O O P .
l s _ c u s t o m e r - d a y s _ a h e a d = r o u n d ( v a l = l s _ c u s t o m e r - d a y s _ a h e a d / l v _ c o u n t d e c = 2 m o d e = c
I N S E R T l s _ c u s t o m e r I N T O T A B L E c t _ c u s t o m e r s .
* S O R T c t _ c u s t o m e r s B Y i d . " a l r e a d y s o r t e d
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * * * * * * * * * * * * * *
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 3 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 147/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
T R Y .
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
l v _ s q l = | S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , A V G ( D A Y S _ A H E A D ) A S D A Y S _ A H E A D | & &
| F R O M _ S Y S _ B I C . " y h a 4 0 0 . d e m o / A T _ D A Y S _ A H E A D " | & &
| W H E R E M A N D T = { s y - m a n d t } | & &
| G R O U P B Y M A N D T , I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y | & &
| O R D E R B Y M A N D T , I D | .
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
G E T R E F E R E N C E O F c t _ c u s t o m e r s I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
C o n t i n u e d o n n e x t p a g e
1 3 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 148/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
E N D F O R M . "
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 3 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 149/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
1 3 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 150/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
E x e r c is e 1 0 : C a ll a S A P H A N A v ie w w i t h a n
i n p u t p a r a m e t e r i n a n a t i v e S Q L S E L E C T
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• a n a l y z e a n d u n d e r s t a n d s c r i p t e d c a l c u l a t i o n v i e w s d e n e d o n S A P H A N A
• k n o w h o w to p ro v id e v a lu e s fo r in p u t p a ra m e te rs o f S A P H A N A v ie w s
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ U S E _ H A N A _ V I E W T 2
S o l u t i o n :
R e p o rt Y H A 4 0 0 _ U S E _ H A N A _ V IE W _ S 2
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ H A N A _ V I E W _ T 2 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ H V I E W _ 2 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A n a l y z e t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e . P a y s p e c i a l
a t t e n t i o n t o t h e W H E R E - c l a u s e o f t h e S E L E C T s t a t e m e n t .
3 . W h a t i s d i f f e r e n t t o t h e p r o g r a m s u s e d i n t h e p r e v i o u s e x e r c i s e s ?
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 3 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 151/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
T a s k 2 : A n a l y z e a s c r i p t e d c a l c u l a t i o n v i e w
I n th e S A P H A N A S t u d i o , a n a l y z e t h e d e n i t i o n o f t h e s c r i p t e d c a l c u l a t i o n v i e w
C A _ C U S T _ W IT H _ A V G _ D A Y S _ A H E A D . C h e c k a l l r e l e v a n t p r o p e r t i e s o f t h e
v ie w , d is p l a y th e r a w d a t a a n d d o a l i t t l e a n a l y s i s o f t h e v i e w ’ s c o n t e n t w i t h t h e
d a ta p re v ie w to o l .
1 . G o t o t h e S A P H A N A S tu d i o , s e a r c h f o r v i e w
C A _ C U S T _ W I T H _ A V G _ D A Y S _ A H E A D a n d o p e n i t s d e n i t i o n .
2 . A n a l y z e t h e v i e w s d e n i t i o n .
3 . V ie w C A _ C U S T _ W IT H _ A V G _ D A Y S _ A H E A D i s a s c r i p t e d
c a lc u la tio n v ie w . T h e s c r ip t h a s in p u t p a ra m e t e r n a m e d
. T h e s c r i p t ’ s o u t p u t
p a r a m e t e r v a r _ o u t h a s c o m p o n e n ts . T h e s c r i p t r s t d e c i d e s ,
A ll d a ta a re s e le c te d f r o m
.
T h e V ie w s o u tp u t c o n s is ts o f e l d s , a l l o f
w h ic h a r e m a p p e d t o t h e c o m p o n e n ts o f
. .
O n e o f th e v ie w e ld s is c la s s i e d a s , th e r e s t a r e
.
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
T a s k 3 : U s e th e S A P H A N A V ie w in a n a t iv e S Q L S e le c t
E d it y o u r p ro g ra m . C o p y th e s o u rc e c o d e o f su b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a ta _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . R e p l a c e t h e n a t i v e
S Q L S E L E C T fro m A T _ D A Y S _ A H E A D w ith a s e le c t fro m c a lc u l a t i o n v i e w
C A _ C U S T _ W IT H _ A V G _ D A Y S _ A H E A D . M a k e s u re to s u p p ly t h e v i e w ’ s i n p u t
p a ra m e t e r F L I G H T S _ B E F O R E w i t h t h e c u rre n t d a t e .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c h a n g e t h e n a t i v e S Q L S t a t e m e n t . I n t h e
F R O M - c l a u s e , r e p l a c e t h e a t t r i b u t e v i e w w i t h t h e c a l c u l a t i o n v i e w y o u j u s t
f o u n d .
3 . A d ju s t t h e e ld lis t o f y o u r S Q L s ta te m e n t to m a tc h th e e ld n a m e s o f t h e
c a lc u la tio n v ie w . B e c a u s e th e a g g re g a tio n is a lr e a d y d o n e in th e v i e w ’ s
s c rip t, r e m o v e th e a g g re g a tio n fu n c tio n A V G ( ) a n d th e G R O U P B Y
a d d itio n . A ls o re m o v e th e O R D E R B Y a d d itio n a s it to o is p a rt o f t h e s c r i p t
in s id e th e v i e w .
C o n t i n u e d o n n e x t p a g e
1 3 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 152/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
4 . S u p p l y th e v ie w s in p u t p a r a m e te r w it h th e c u r r e n t d a te f r o m s y s te m e l d
( s y - d a t u m )
H i n t : T h e H A N A n a t i v e S Q L s y n t a x i s ( ’ P L A C E -
H O L D E R ’ = ( ’ $ $ F L I G H T S _ B E F O R E $ $ ’ , ’ < v a l u e > ’ ) ) , w h e r e
< v a l u e > s t a n d s f o r t h e c u r r e n t d a t e i n i n t e r n a l f o r m a t .
5 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 3 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 153/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
S o lu tio n 1 0 : C a ll a S A P H A N A v ie w w i t h a n
i n p u t p a r a m e t e r i n a n a t i v e S Q L S E L E C T
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ H A N A _ V I E W _ T 2 i n y o u r p a c k a g e Z H A 4 0 0 _ # #
( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ H V I E W _ 2 , w h e r e # # i s y o u r g r o u p n u m b e r ) .
A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A n a l y z e t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e . P a y s p e c i a l
a t t e n t i o n t o t h e W H E R E - c l a u s e o f t h e S E L E C T s t a t e m e n t .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
3 . W h a t i s d i f f e r e n t t o t h e p r o g r a m s u s e d i n t h e p r e v i o u s e x e r c i s e s ?
A n s w e r : O n l y s u c h b o o k i n g s a r e t a k e n i n t o a c c o u n t w h e r e t h e i g h t d a t e
l i e s i n t h e p a s t .
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : A n a l y z e a s c r i p t e d c a l c u l a t i o n v i e w
I n th e S A P H A N A S t u d i o , a n a l y z e t h e d e n i t i o n o f t h e s c r i p t e d c a l c u l a t i o n v i e w
C A _ C U S T _ W IT H _ A V G _ D A Y S _ A H E A D . C h e c k a l l r e l e v a n t p r o p e r t i e s o f t h e
v ie w , d is p l a y th e r a w d a t a a n d d o a l i t t l e a n a l y s i s o f t h e v i e w ’ s c o n t e n t w i t h t h e
d a ta p re v ie w to o l .
1 . G o t o t h e S A P H A N A S tu d i o , s e a r c h f o r v i e w
C A _ C U S T _ W I T H _ A V G _ D A Y S _ A H E A D a n d o p e n i t s d e n i t i o n .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . A n a l y z e t h e v i e w s d e n i t i o n .
a ) D o u b l e c l i c k o n S c r i p t _ . . . t o s e e t h e S Q L s c r i p t i n s i d e t h e v i e w , t h e
o u t p u t p a r a m e t e r o f t h e s c r i p t a n d i t s i n p u t p a r a m e t e r s .
b ) D o u b l e c l i c k o n O u t p u t t o s e e h o w t h e c o m p o n e n t s o f t h e s c r i p t ’ s i n p u t
p a r a m e t e r a r e m a p p e d t o e l d s o f t h e c a l c u l a t i o n v i e w .
C o n t i n u e d o n n e x t p a g e
1 4 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 154/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
3 . V i e w C A _ C U S T _ W I T H _ A V G _ D A Y S _ A H E A D i s a s c r i p te d c a l c u la t i o n
v i e w . T h e s c r i p t h a s 1 i n p u t p a r a m e t e r n a m e d F L I G H T S _ B E F O R E . T h e
s c r i p t ’ s o u t p u t p a r a m e t e r v a r _ o u t h a s 7 c o m p o n e n ts . T h e s c rip t rs t d e c i d e s ,
w h e t h e r t h e i n p u t p a r a m e t e r c o n ta in s a n o n - in itia l v a lu e o r n o t. A ll d a t a
a r e s e le c te d f r o m a ttr ib u te v ie w A T _ D A Y S _ A H E A D .T h e V ie w s o u tp u t
c o n s is ts o f 7 e ld s , a ll o f w h ic h a re m a p p e d to th e c o m p o n e n ts o f th e s c r i p t s
o u t p u t p a r a m e t e r v a r _ o u t . . O n e o f th e v i e w e ld s is c la s s i e d a s M e a s u r e ,
t h e r e s t a r e A t t r i b u t e s .
A n s w e r : 1 , F L I G H T S _ B E F O R E , 7 , w h e t h e r t h e i n p u t p a r a m e t e r c o n t a i n s a
n o n - i n i t i a l v a l u e o r n o t , a t t r i b u t e v i e w A T _ D A Y S _ A H E A D , 7 , t h e s c r i p t s
o u t p u t p a r a m e t e r v a r _ o u t , M e a s u r e , A t t r i b u t e s
T a s k 3 : U s e th e S A P H A N A V ie w in a n a t i v e S Q L S e le c t
E d it y o u r p ro g ra m . C o p y th e so u rc e c o d e o f su b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a ta _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . R e p l a c e t h e n a t i v e
S Q L S E L E C T fro m A T _ D A Y S _ A H E A D w ith a s e le c t fro m c a lc u l a t i o n v i e w
C A _ C U S T _ W IT H _ A V G _ D A Y S _ A H E A D . M a k e s u re to s u p p ly t h e v ie w ’ s i n p u t
p a ra m e t e r F L I G H T S _ B E F O R E w i t h t h e c u rre n t d a t e .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , c h a n g e t h e n a t i v e S Q L S t a t e m e n t . I n t h e
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
3 . A d ju s t t h e e ld lis t o f y o u r S Q L s ta te m e n t to m a tc h th e e ld n a m e s o f t h e
c a lc u l a tio n v ie w . B e c a u s e th e a g g re g a tio n is a lre a d y d o n e in th e v i e w ’ s
s c rip t, r e m o v e th e a g g re g a tio n fu n c tio n A V G ( ) a n d th e G R O U P B Y
a d d itio n . A ls o re m o v e th e O R D E R B Y a d d itio n a s it to o is p a rt o f t h e s c r i p t
in s id e th e v i e w .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
4 . S u p p l y th e v ie w s in p u t p a r a m e te r w it h th e c u r r e n t d a te f r o m s y s te m e l d
( s y - d a t u m )
H i n t : T h e H A N A n a t i v e S Q L s y n t a x i s ( ’ P L A C E -
H O L D E R ’ = ( ’ $ $ F L I G H T S _ B E F O R E $ $ ’ , ’ < v a l u e > ’ ) ) , w h e r e
< v a l u e > s t a n d s f o r t h e c u r r e n t d a t e i n i n t e r n a l f o r m a t .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 4 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 155/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
5 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ U S E _ H A N A _ V I E W _ S 2 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
T R Y .
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
C o n t i n u e d o n n e x t p a g e
1 4 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 156/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
l v _ s q l = | S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , A V G ( D A Y S _ A H E A D ) A S D A Y S _ A H E A D |
| F R O M _ S Y S _ B I C . " y h a 4 0 0 . d e m o / A T _ D A Y S _ A H E A D " | & &
| W H E R E M A N D T = { s y - m a n d t } | & &
| A N D F L D A T E < { s y - d a t u m } | & &
| G R O U P B Y M A N D T , I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y | & &
| O R D E R B Y M A N D T , I D | .
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
G E T R E F E R E N C E O F c t _ c u s t o m e r s I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 4 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 157/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
T R Y .
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
l v _ s q l = | S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , A V G _ D A Y S _ A H E A D A S D A Y S _ A H E A D | & &
| F R O M _ S Y S _ B I C . " y h a 4 0 0 . d e m o / C A _ C U S T _ W I T H _ A V G _ D A Y S _ A H E A D " | & &
| ( ' P L A C E H O L D E R ' = ( ' $ $ F L I G H T S _ B E F O R E $ $ ' , ' { s y - d a t u m } ' ) ) | & &
| W H E R E M A N D T = { s y - m a n d t } | .
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
G E T R E F E R E N C E O F c t _ c u s t o m e r s I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
1 4 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 158/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C o n s u m in g S A P H A N A V ie w s in A B A P
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• C o n s u m e H A N A v ie w s in A B A P
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 4 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 159/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• C a ll H A N A p r o c e d u r e s i n A B A P
B u s i n e s s E x a m p l e
F ig u r e 6 4 : C a llin g H A N A P r o c e d u r e s w i t h O v e r v i e w
1 4 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 160/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
F ig u r e 6 5 : C a llin g H A N A P r o c e d u r e s – R e t r i e v e o n e R e s u l t S e t
F ig u r e 6 6 : C a llin g H A N A P r o c e d u r e s w it h O v e r v ie w – N a t i v e S Q L S y n t a x
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 4 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 161/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
F ig u r e 6 7 : C o d i n g E x a m p le : C a llin g H A N A P r o c e d u r e w i t h O v e r v i e w
F ig u r e 6 8 : C o d in g E x a m p le : R e tr ie v in g R e s u lt f ro m O v e r v i e w
1 4 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 162/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
E x e r c i s e 1 1 : A n a l y z e a s t o r e d p r o c e d u r e
dn ae t i nv ee d S Qo n L S s At a P t e H m A e N n t A a n d c a l l i t i n a
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• a n a l y z e a n d u n d e r s t a n d s t o r e d p r o c e d u r e s d e n e d o n S A P H A N A
• c a ll S A P H A N A s t o r e d p r o c e d u r e s v ia n a t i v e S Q L
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ C A L L _ P R O C E D U R E _ T 1
S o l u t i o n :
R e p o r t Y H A 4 0 0 _ C A L L _ P R O C E D U R E _ S 1
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ C A L L _ P R O C E D U R E _ T 1 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ H P R O C _ 1 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A n a l y z e t h e s o u r c e c o d e , a c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A n a l y z e t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e . P a y s p e c i a l
a t t e n t i o n t o t h e c h a n g i n g p a r a m e t e r s o f t h e r o u t i n e a n d h o w t h e y a r e l l e d
w i t h d a t a .
3 . W h a t i s th e m a in d if f e r e n c e b e tw e e n th is p ro g ra m a n d t h e o n e s w e u s e d
b e f o r e ?
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 4 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 163/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
T a s k 2 : A n a ly z e a S A P H A N A s t o r e d p r o c e d u r e
I n t h e S A P H A N A S t u d i o , a n a l y z e t h e d e n i t i o n o f t h e s t o r e d p r o c e d u r e
S P _ E A R L Y _ B I R D _ A N D _ L A S T _ M I N U T E . C h e c k a l l r e l e v a n t p r o p e r t i e s o f
t h e p r o c e d u r e .
1 . G o t o t h e S A P H A N A S t u d i o , s e a r c h f o r p r o c e d u r e
S P _ E A R L Y _ B I R D _ A N D _ L A S T _ M I N U T E a n d o p e n i t s d e n i -
t i o n .
2 . A n a l y z e t h e p r o c e d u r e ’ s d e n i t i o n .
3 . S to r e d p r o c e d u r e S P _ E A R L Y _ B I R D _ A N D _ L A S T _ M I N U T E
h a s in p u t p a r a m e te r s o f n a m e
. T h e y a r e u s e d t o
T h e s c rip t h a s o u tp u t p a r a m e t e r s n a m e d
a n d
E T _ L A S T _ M I N U T E . T h e s c r i p t c o n t a i n s t w o s e l e c t
s t a t e m e n t s w h i c h l o o k a l m o s t i d e n t i c a l . T h e o n l y d i f f e r e n c e i s
F i l l i n t h e b l a n k s t o c o m p l e t e t h e s e n t e n c e .
T a s k 3 : C a ll th e S A P H A N A P r o c e d u r e i n a n a t i v e S Q L
S t a t e m e n t
H in t : T h e p r o c e d u r e e x p e c t s f o u r p a r a m e te rs s e p a ra te d b y c o l o n s .
T h e r s t tw o a re in p u t p a r a m e te rs . P ro v id e s u ita b le v a lu e s f o r
th e m ( c o n t e n t o f d a t a o b j e c t s p v _ n u m b e r a n d s y - m a n d t ) . T h e l a s t
tw o p a r a m e te rs c o r r e s p o n d to th e o u tp u t p a r a m e te rs . th e y c a n b e
su p p lie d w ith “ n u l l” w h e n u s in g a d d i t i o n W IT H O V E R V IE W .
C o n t i n u e d o n n e x t p a g e
1 5 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 164/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
3 . D e n e a n i n t e r n a l t a b l e w i t h t w o c o l u m n s o f t y p e s t r i n g . ( s u g g e s t e d n a m e
f o r t h e t a b l e : l t _ o v e r v i e w , s u g g e s t e d n a m e s f o r t h e c o l u m n s : p a r a m a n d
v a l u e ) . R e p l a c e t a r g e t d a t a o b j e c t c t _ c u s t _ l a t e w i t h t h i s n e w i n t e r n a l t a b l e . .
4 . A f t e r y o u c l o s e d t h e r s t q u e r y w i t h t h e c a l l o f t h e p r o c e d u r e , u s e s t a t e m e n t
R E A D T A B L E t o r e a d t h e l i n e f r o m l t _ o v e r v i e w w h e r e c o l u m n p a r a m
c o n t a i n s t h e n a m e o f p r o c e d u r e p a r a m e t e r E T _ E A R L Y _ B I R D S . U s e t h e
c o n t e n t o f c o l u m n v a l u e i n t h e F R O M - c l a u s e o f a n a t i v e S Q L S E L E C T .
B y t h a t y o u r e a d t h e c o n t e n t o f t h e p r o c e d u r e s e x p o r t p a r a m e t e r f r o m t h e
d a t a b a s e . U s e t h e s u b r o u t i n e s p a r a m e t e r c t _ c u s t _ e a r l y a s t a r g e t f o r t h i s
S E L E C T - s t a t e m e n t .
5 . A fte r y o u c lo s e d th is s e c o n d q u e ry , u se s ta te m e n t R E A D T A B L E t o r e a d t h e
lin e f r o m l t _ o v e r v i e w w h e r e c o l u m n p a r a m c o n t a i n s t h e n a m e o f p r o c e d u r e
p a r a m e t e r E T _ L A S T _ M IN U T E . A g a i n , u s e th e c o n t e n t o f c o l u m n v a l u e i n t h e
F R O M -c la u s e o f a n a tiv e S Q L S E L E C T . B u t th i s t i m e u s e t h e s u b r o u t i n e s
p a r a m e t e r c t _ c u s t_ l a t e a s t h e ta rg e t f o r th e S E L E C T - s t a t e m e n t .
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . U s e t h e d e b u g g e r t o a n a l y z e t h e c o n t e n t o f
t h e o v e r v i e w t a b l e a n d t h e r e t r i e v a l o f t h e p r o c e d u r e s r e s u l t s . M a k e s u r e t h e
t w o s u b r o u t i n e s d e l i v e r e x a c t l y t h e s a m e d a t a .
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 5 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 165/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
S o l u t i o n 1 1 : A n a l y z e a s t o r e d p r o c e d u r e
dn ae t i nv ee d S Qo n L S s At a P t e H m A e N n t A a n d c a ll it in a
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ C A L L _ P R O C E D U R E _ T 1 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ H P R O C _ 1 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A n a l y z e t h e s o u r c e c o d e , a c t i v a t e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A n a l y z e t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e . P a y s p e c i a l
a t t e n t i o n t o t h e c h a n g i n g p a r a m e t e r s o f t h e r o u t i n e a n d h o w t h e y a r e l l e d
w i t h d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
3 . W h a t is th e m a in d if f e r e n c e b e tw e e n th is p ro g ra m a n d t h e o n e s w e u s e d
b e f o r e ?
A n s w e r : I n s t e a d o f j u s t o n e l i s t o f a l l c u s t o m e r s t w o l i s t s a r e g a t h e r e d : O n e
l i s t o f c u s t o m e r s w i t h t h e l o n g e s t a v e r a g e t i m e b e t w e e n o r d e r d a t e a n d i g h t
d a t e a n d l i s t o f c u s t o m e r s w i t h t h e s h o r t e s t a v e r a g e t i m e b e t w e e n o r d e r
d a t e a n d i g h t d a t e .
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : A n a ly z e a S A P H A N A s t o r e d p r o c e d u r e
I n t h e S A P H A N A S t u d i o , a n a l y z e t h e d e n i t i o n o f t h e s t o r e d p r o c e d u r e
S P _ E A R L Y _ B I R D _ A N D _ L A S T _ M I N U T E . C h e c k a l l r e l e v a n t p r o p e r t i e s o f
t h e p r o c e d u r e .
1 . G o to th e S A P H A N A S t u d i o , s e a r c h f o r p r o c e d u r e
S P _ E A R L Y _ B IR D _ A N D _ L A S T _ M IN U T E a n d o p e n i t s d e n i -
t i o n .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . A n a l y z e t h e p r o c e d u r e ’ s d e n i t i o n .
a ) A l l r e l e v a n t i n f o r m a t i o n i s d i r e c t l y v i s i b l e i n t h e p r o c e d u r e d e n i t i o n .
C o n t i n u e d o n n e x t p a g e
1 5 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 166/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
3 . S to r e d p r o c e d u r e S P _ E A R L Y _ B I R D _ A N D _ L A S T _ M I N U T E h a s 2 i n p u t
p a r a m e t e r s o f n a m e i v _ n u m b e r a n d i v _ m a n d t . T h e y a r e u s e d t o r e s t r i c t t h e
c lie n t in th e s e le c t s ta te m e n ts o f th e p r o c e d u re a n d to re s tric t th e n u m b e r
o f d a ta se ts th a t a r e s e le c te d . T h e s c r ip t h a s 2 o u t p u t p a ra m e te rs n a m e d
E T _ E A R L Y _ B I R D S a n d E T _ L A S T _ M I N U T E . T h e s c rip t c o n ta in s tw o s e l e c t
s ta te m e n ts w h ic h lo o k a lm o s t i d e n tic a l. T h e o n ly d iffe re n c e is th e so r t i n g
o rd e r (o n e s o r t s a s c e n d i n g , t h e o t h e r d e s c e n d i n g )
A n s w e r : 2 , i v _ n u m b e r a n d i v _ m a n d t , r e s t r i c t t h e c l i e n t i n t h e s e l e c t
s ta te m e n ts o f th e p r o c e d u r e a n d t o r e s t r i c t t h e n u m b e r o f d a t a s e t s t h a t a r e
s e le c t e d , 2 , E T _ E A R L Y _ B I R D S , t h e s o r t i n g o r d e r ( o n e s o r t s a s c e n d i n g ,
th e o t h e r d e s c en d i n g )
T a s k 3 : C a ll th e S A P H A N A P r o c e d u r e in a n a t iv e S Q L
S t a t e m e n t
E d it y o u r p ro g ra m . C o p y th e so u rc e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . I m p l e m e n t
a n a tiv e S Q L S ta te m e n t th a t c a lls th e s t o r e d p r o c e d u r e . U s e a d d i t i o n W I T H
O V E R V I E W t o r e c e i v e rst a lis t o f n a m e / v a l u e p a i r s f o r t h e e x p o r t p a r a m e t e r s .
U s in g th is lis t, r e trie v e th e c o n te n t o f t h e e x p o r t p a r a m e t e r s v i a n a t i v e S Q L S e l e c t s
f r o m t h e d a t a b a s e .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c t i o n o f t h e A B A P E d i t o r .
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , r e p l a c e t h e s t r i n g w i t h t h e n a t i v e S Q L
S E L E C T w i t h c a l l o f t h e s t o r e d p r o c e d u r e . U s e a d d i t i o n W I T H O V E R V I E W .
H i n t : T h e p r o c e d u r e e x p e c ts f o u r p a r a m e te rs s e p a ra te d b y c o l o n s .
T h e rs t tw o a re in p u t p a r a m e te rs . P r o v i d e s u ita b le v a lu e s f o r
th e m (c o n t e n t o f d a t a o b j e c t s p v _ n u m b e r a n d s y - m a n d t ) . T h e l a s t
tw o p a ra m e te rs c o r r e s p o n d to th e o u t p u t p a r a m e te rs . th e y c a n b e
s u p p lie d w i t h “ n u l l ” w h e n u s i n g a d d i t i o n W IT H O V E R V IE W .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
3 . D e n e a n i n t e r n a l t a b l e w i t h t w o c o l u m n s o f t y p e s t r i n g . ( s u g g e s t e d n a m e
f o r t h e t a b l e : l t _ o v e r v i e w , s u g g e s t e d n a m e s f o r t h e c o l u m n s : p a r a m a n d
v a l u e ) . R e p l a c e t a r g e t d a t a o b j e c t c t _ c u s t _ l a t e w i t h t h i s n e w i n t e r n a l t a b l e . .
a ) S e e s o u r c e c o d e e x tr a c t f r o m m o d e l s o l u t i o n .
4 . A f t e r y o u c l o s e d t h e r s t q u e r y w i t h t h e c a l l o f t h e p r o c e d u r e , u s e s t a t e m e n t
R E A D T A B L E t o r e a d t h e l i n e f r o m l t _ o v e r v i e w w h e r e c o l u m n p a r a m
c o n t a i n s t h e n a m e o f p r o c e d u r e p a r a m e t e r E T _ E A R L Y _ B I R D S . U s e t h e
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 5 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 167/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
c o n t e n t o f c o l u m n v a l u e i n t h e F R O M - c l a u s e o f a n a t i v e S Q L S E L E C T .
B y t h a t y o u r e a d t h e c o n t e n t o f t h e p r o c e d u r e s e x p o r t p a r a m e t e r f r o m t h e
d a t a b a s e . U s e t h e s u b r o u t i n e s p a r a m e t e r c t _ c u s t _ e a r l y a s t a r g e t f o r t h i s
S E L E C T - s t a t e m e n t .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
5 . A fte r y o u c lo s e d th is s e c o n d q u e ry , u s e s ta te m e n t R E A D T A B L E t o r e a d t h e
lin e f r o m l t _ o v e r v i e w w h e r e c o l u m n p a r a m c o n t a i n s t h e n a m e o f p r o c e d u r e
p a r a m e t e r E T _ L A S T _ M IN U T E . A g a i n , u s e t h e c o n t e n t o f c o l u m n v a l u e i n t h e
F R O M - c la u s e o f a n a tiv e S Q L S E L E C T . B u t th i s t i m e u s e t h e s u b r o u t i n e s
p a r a m e t e r c t _ c u s t_ l a t e a s t h e ta rg e t f o r th e S E L E C T - s t a t e m e n t .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
6 . A c t i v a t e a n d t e s t y o u r p r o g r a m . U s e t h e d e b u g g e r t o a n a l y z e t h e c o n t e n t o f
t h e o v e r v i e w t a b l e a n d t h e r e t r i e v a l o f t h e p r o c e d u r e s r e s u l t s . M a k e s u r e t h e
t w o s u b r o u t i n e s d e l i v e r e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ C A L L _ P R O C E D U R E _ S 1 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e U S I N G p v _ n u m b e r T Y P E i
C H A N G I N G c t _ c u s t _ e a r l y T Y P E t y _ t _ c u s t o m e r s
c t _ c u s t _ l a t e T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
C o n t i n u e d o n n e x t p a g e
1 5 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 168/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R : c t _ c u s t _ e a r l y ,
c t _ c u s t _ l a t e .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
l v _ s q l = | S E L E C T T O P { p v _ n u m b e r } | & &
| I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , A V G ( D A Y S _ A H E A D ) A S D A Y S _ A H E A D | & &
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F c t _ c u s t _ e a r l y I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
* c r e a t e s e c o n d S Q L s t a t e m e n t
l v _ s q l = | S E L E C T T O P { p v _ n u m b e r } | & &
| I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , A V G ( D A Y S _ A H E A D ) A S D A Y S _ A H E A D | & &
| F R O M _ S Y S _ B I C . " y h a 4 0 0 . d e m o / A T _ D A Y S _ A H E A D " | & &
| W H E R E M A N D T = { s y - m a n d t } | & &
| G R O U P B Y M A N D T , I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y | & &
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 5 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 169/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
| O R D E R B Y M A N D T , D A Y S _ A H E A D A S C | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F c t _ c u s t _ l a t e I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n U S I N G p v _ n u m b e r T Y P E i
C H A N G I N G c t _ c u s t _ e a r l y T Y P E t y _ t _ c u s t o m e r s
c t _ c u s t _ l a t e T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* t y p e f o r r e s u l t o v e r v i e w
T Y P E S : B E G I N O F l t y _ s _ o v e r v i e w ,
p a r a m T Y P E s t r i n g ,
v a l u e T Y P E s t r i n g ,
E N D O F l t y _ s _ o v e r v i e w .
* D a t a o b j e c t s f o r r e s u l t o v e r v i e w
D A T A : l t _ o v e r v i e w T Y P E T A B L E O F l t y _ s _ o v e r v i e w ,
l s _ o v e r v i e w T Y P E l t y _ s _ o v e r v i e w .
* h e l p v a r i a b l e s
D A T A l v _ c o u n t T Y P E i .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
C o n t i n u e d o n n e x t p a g e
1 5 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 170/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
C L E A R : c t _ c u s t _ e a r l y ,
c t _ c u s t _ l a t e .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t o v e r v i e w i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F l t _ o v e r v i e w I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
* R e t r i e v e t h e r e s u l t s
* 1 . P a r a m e t e r e t _ e a r l y _ b i r d s
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 5 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 171/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 4 : C o n s u m in g H A N A V ie w s a n d P r o c e d u r e s in A B A P H A 4 0 0
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
* 2 . P a r a m e t e r e t _ l a s t _ m i n u t e
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
1 5 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 172/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C a llin g S A P H A N A P r o c e d u r e s in A B A P
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• C a ll H A N A p r o c e d u r e s i n A B A P
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 5 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 173/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it S u m m a r y H A 4 0 0
U n it S u m m a r y
Y o u s h o u ld n o w b e a b l e t o :
• W o rk w ith v ie w s in th e S A P H A N A S tu d i o
• D e s c r ib e th e d if f e r e n t T y p e s o f S A P H A N A v i e w s
• C o n su m e H A N A v ie w s in A B A P
• C a ll H A N A p r o c e d u r e s i n A B A P
1 6 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 174/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 175/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 176/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n i t 5
C r e a t i n g A n a l y t i c a l V i e w
U n i t O v e r v i e w
T h i s U n i t i s d e s i g n e d t o t e a c h t h e c r e a t i o n o f A n a l y t i c V i e w s
U n i t O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s u n i t , y o u w i l l b e a b l e t o :
• C r e a t e a n A n a l y ti c v ie w
U n i t C o n t e n t s
L e s s o n : C r e a t i n g A n a l y t i c V i e w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 6 2
E x e r c is e 1 2 : C r e a te a S A P H A N A a n a ly t ic v ie w a n d u s e it in A B A P v ia
a n a t i v e S Q L S E L E C T . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 6 7
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 6 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 177/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
L e s s o n : C r e a t i n g A n a l y t i c V i e w
L e s s o n O v e r v i e w
L e s s o n O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s l e s s o n , y o u w i l l b e a b l e t o :
• C r e a t e a n A n a l y ti c v ie w
B u s i n e s s E x a m p l e
F ig u r e 6 9 : C r e a tin g A n a l y t i c V i e w
1 6 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 178/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 6 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 179/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
F i g u r e 7 3 : E x a m p l e : D e n e R e s t r i c t e d C o l u m n
F i g u r e 7 4 : E x a m p l e : D e n e C a l c u l a t e d M e a s u r e
1 6 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 180/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 6 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 181/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
1 6 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 182/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
E x e r c is e 1 2 : C r e a t e a S A P H A N A a n a ly t i c
vS i E e L w E a C n T d u s e i t i n A B A P v ia a n a t iv e S Q L
E x e r c i s e O b j e c t i v e s
A f t e r c o m p l e t i n g t h i s e x e r c i s e , y o u w i l l b e a b l e t o :
• c re a te a n a n a ly tic v ie w o n S A P H A N A
• u n d e rs ta n d a n d u s e th e S A P H A N A b u il t - i n c u r r e n c y c o n v e r s i o n
• u se S A P H A N A a n a l y t i c v i e w s i n A B A P u s i n g A D B C a n d a n a t i v e S Q L
S E L E C T
B u s i n e s s E x a m p l e
T e m p l a t e :
R e p o r t Y H A 4 0 0 _ C R E A T E _ H A N A _ V I E W T 1
S o l u t i o n :
R e p o rt Y H A 4 0 0 _ C R E A T E _ H A N A _ V IE W _ S 1
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C re a te a c o p y o f re p o rt Y H A 4 0 0 _ C R E A T E _ H A N A _ V IE W _ T 1 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ C V I E W _ 1 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A c t i v a t e , a n a l y z e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
2 . A n a l y z e t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e .
3 . W h a t i s c a l c u l a t e d i n t h e l o o p o v e r t h e c u s t o m e r s i g h t b o o k i n g s ? H o w
i s t h i s d o n e ?
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 6 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 183/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
T a s k 2 : C r e a t e a n a n a l y t i c v i e w
I n t h e S A P H A N A S t u d i o , c r e a t e a v i e w t h a t c o n t a i n s t h e c o m p l e t e a n a l y s i s f o u n d
i n s u b r o u t i n e g e t _ d a t a _ t e m p l a t e . M a k e u s e o f t h e f a c t t h a t S A P H A N A s u p p o r t s
c u r r e n c y c o n v e r s i o n s a n d a g g r e g a t i o n s i n a n a l y t i c v i e w s .
1 . G o t o t h e S A P H A N A S t u d i o . I n t h e N a v ig a t o r , s e a r c h f o r t h e c o n t e n t
p a c k a g e y o u c r e a t e d i n E x e r c i s e 1 .
2 . I n y o u r p a c k a g e , c r e a te a n e w a n a ly tic v ie w ( s u g g e s t e d n a m e :
A N _ C U S T _ W I T H _ P A Y S U M ) .
3 . I n t h e D a t a F o u n d a t i o n , d e n e a r e f e r e n t i a l j o i n o f t a b l e s S C U S T O M a n d
S B O O K w i t h a s u i t a b l e j o i n c o n d i t i o n .
4 . A d d a l l r e q u i r e d e l d s t o t h e v i e w s o u t p u t ( S e e t e m p l a t e p r o g r a m ) . S e t a
l t e r o n c o l u m n C A N C E L L E D t o m a k e s u r e o n l y n o n - c a n c e l l e d b o o k i n g s
a r e c o n s i d e r e d .
5 . I n t h e L o g i c a l J o i n o f t h e v i e w , d e n e a c a lc u la te d c o lu m n ( s u g g e s t e d
n a m e : P A Y S U M _ C O N V ) o f s u i t a b l e ty p e th a t c o n v e r ts th e c o n t e n t o f
c o l u m n F O R C U R A M t o c u r r e n c y U S D . U s e th e s a m e e x c h a n g e t y p e ( =
T Y P E _ O F _ R A T E ) a n d c o n v e r s i o n d a te u s e d fo r th e fu n c tio n m o d u l e i n t h e
te m p la te p r o g r a m .
6 . I n t h e S e m a n t i c s o f t h e v i e w , d e c l a r e t h e c a l c u l a t e d c o l u m n P A Y S U M a n d t h e
c u r r e n c y a m o u n t F O R C U R A M t o b e o f t y p e M e a s u r e a n d a l l o t h e r c o l u m n s
t o b e o f t y p e A t t r i b u t e .
7 . B a c k i n t h e o f t h e v i e w , h i d e a l l c o l u m n s f r o m t h e v i e w ’ s o u t p u t t h a t a r e o n l y
n e e d e d a s i n p u t f o r t h e c u r r e n c y c o n v e r s i o n .
8 . S a v e a n d A c t i v a t e y o u r v i e w .
T a s k 3 : U s e th e S A P H A N A V ie w in a n a t iv e S Q L S e le c t
E d it y o u r p ro g ra m . C o p y th e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . R e p l a c e t h e t w o
S E L E C T s , th e n e s te d L O O P s , th e c u r r e n c y c o n v e r s i o n a n d t h e a g g r e g a t i o n b y
j u s t o n e s e le c t fro m y o u r a n a ly tic v i e w .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
2 . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n , i m p l e m e n t a n A D B C c a l l o f a n a t i v e S Q L
S E L E C T t h a t r e a d s d a t a f r o m t h e v i e w y o u j u s t c r e a t e d . M a k e t h e s e l e c t r e a d
i n t o d a t a o b j e c t s c t _ c u s t o m e r s d i r e c t l y .
3 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
4 . P e r f o r m a R u n t i m e M e a s u r e m e n t a n d Q u a n t i f y t h e i m p r o v e m e n t y o u
a c h i e v e d .
1 6 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 184/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
S o lu tio n 1 2 : C r e a te a S A P H A N A a n a ly t i c
vS i E e L w E a C n T d u s e i t i n A B A P v ia a n a t iv e S Q L
T a s k 1 : C o p y a n d u n d e r s t a n d t e m p l a t e
C r e a t e a c o p y o f r e p o r t Y H A 4 0 0 _ C R E A T E _ H A N A _ V I E W _ T 1 i n y o u r p a c k a g e
Z H A 4 0 0 _ # # ( s u g g e s t e d n a m e : Z H A 4 0 0 _ # # _ C V I E W _ 1 , w h e r e # # i s y o u r g r o u p
n u m b e r ) . A c t i v a t e , a n a l y z e a n d e x e c u t e t h e p r o g r a m .
1 . C r e a t e a c o p y o f t h e r e p o r t . P l a c e i t i n y o u r p a c k a g e Z H A 4 0 0 _ 0 0 a n d a s s i g n
i t t o y o u r w o r k b e n c h t a s k .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
2 . A n a l y z e t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
3 . W h a t i s c a l c u l a t e d i n t h e l o o p o v e r t h e c u s t o m e r s i g h t b o o k i n g s ? H o w
i s t h i s d o n e ?
A n s w e r : T h e p a y m e n t i n l o c a l c u r r e n c y i s c o n v e r t e d t o U S D o l l a r . T h i s
i s d o n e v i a f u n c t i o n m o d u l e C O N V E R T _ T O _ L O C A L _ C U R R E N C Y . T h e
p a y m e n t s a r e t h e n s u m m e d u p p e r c u s t o m e r .
4 . A c t i v a t e a n d e x e c u t e t h e p r o g r a m .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
T a s k 2 : C r e a t e a n a n a l y t i c v i e w
I n t h e S A P H A N A S t u d i o , c r e a t e a v i e w t h a t c o n t a i n s t h e c o m p l e t e a n a l y s i s f o u n d
i n s u b r o u t i n e g e t _ d a t a _ t e m p l a t e . M a k e u s e o f t h e f a c t t h a t S A P H A N A s u p p o r t s
c u r r e n c y c o n v e r s i o n s a n d a g g r e g a t i o n s i n a n a l y t i c v i e w s .
1 . G o t o t h e S A P H A N A S t u d i o . I n t h e N a v i g a t o r , s e a r c h f o r t h e c o n t e n t
p a c k a g e y o u c r e a t e d i n E x e r c i s e 1 .
a ) P e rfo rm t h i s s t e p a s b e f o r e .
2 . In y o u r p a c k a g e , c re a te a n e w a n a ly tic v ie w ( s u g g e s t e d n a m e :
) .
A N _ C U S T _ W I T H _ P A Y S U M
a ) R i g h t c l i c k o n t h e p a c k a g e a n d c h o o s e N e w - > A n a l y t i c V i e w . . . .
b ) E n te r th e n a m e o f th e v ie w a n d a d e s c r i p t i o n , t h e n p r e s s F i n i s h
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 6 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 185/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
3 . I n t h e D a t a F o u n d a t i o n , d e n e a r e f e r e n t i a l j o i n o f t a b l e s S C U S T O M a n d
S B O O K w i t h a s u i t a b l e j o i n c o n d i t i o n .
a ) I n t h e N a v i g a t o r , o p e n t h e s c h e m a a n d t h e n o d e w i t h t h e t w o t a b l e s .
b ) U s e t h e D r a g & D r o p - f u n c t i o n t o a d d t h e t a b l e s t o t h e d a t a f o u n d a t i o n .
c ) U s e t h e D r a g & D r o p - f u n c t i o n t o j o i n e l d S C U S T O M . M A N D T w i t h
S B O O K . M A N D T a n d S C U S T O M . I D w i t h S B O O K . C U S T O M I D .
d ) C l i c k o n o n e o f t h e j o i n l i n e s a n d , o n t h e l o w e r r i g h t , c h e c k t h e j o i n
t y p e a n d c a r d i n a l i t y . A d j u s t t h i s i n f o r m a t i o n i f n e c e s s a r y .
4 . A d d a l l r e q u i r e d e l d s t o t h e v i e w s o u t p u t ( S e e t e m p l a t e p r o g r a m ) . S e t a
l t e r o n c o l u m n C A N C E L L E D t o m a k e s u r e o n l y n o n - c a n c e l l e d b o o k i n g s
a r e c o n s i d e r e d .
a ) C l i c k o n t h e g r e y b u l l e t n e x t t o a t a b l e e l d t o a d d i t t o t h e o u t p u t ( t h e
b u l l e t ’ s c o l o r w i l l t h e n c h a n g e t o o r a n g e ) . T h e r e q u i r e d e l d s a r e :
• S C U S T O M .M A N D T
• S C U S T O M . I D
• S C U S T O M .N A M E
• S C U S T O M .P O S T C O D E
• S C U S T O M .C I T Y
• S C U S T O M .C O U N T R Y
• S B O O K .O R D E R _ D A T E
• S B O O K . F O R C U R A M
• S B O O K . F O R C U R K E Y
b ) R i g h t c l i c k o n e l d S B O O K . C A N C E L L E D a n d c h o o s e A p p l y l t e r t o
s e t t h e l t e r .
C o n t i n u e d o n n e x t p a g e
1 7 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 186/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
5 . I n t h e L o g i c a l J o i n o f t h e v i e w , d e n e a c a l c u l a t e d c o l u m n ( s u g g e s t e d
n a m e : P A Y S U M _ C O N V ) o f s u i t a b l e t y p e t h a t c o n v e r t s t h e c o n t e n t o f
c o l u m n F O R C U R A M t o c u r r e n c y U S D . U s e t h e s a m e e x c h a n g e t y p e ( =
T Y P E _ O F _ R A T E ) a n d c o n v e r s i o n d a t e u s e d f o r t h e f u n c t i o n m o d u l e i n t h e
t e m p l a t e p r o g r a m .
a ) I n t h e S c e n a r i o w i n d o w o n t h e l e f t , c l i c k o n L o g i c a l J o i n t o s w i t c h t o
t h e d e n i t i o n o f t h e v i e w l o g i c .
b ) I n t h e O u t p u t w i n d o w o n t h e r i g h t , r i g h t - c l i c k o n n o d e C a l c u l a t e d
C o l u m n s a n d C h o o s e N e w . . .
c ) E n t e r a n a m e a n d a d e s c r i p t i o n f o r t h e c a l c u l a t e d c o l u m n a n d s e t t h e
d a t a t y p e t o D E C I M A L w i t h d i m e n s i o n = 1 6 a n d s c a l e = 4
d ) C h a n g e t h e c o l u m n t y p e f r o m A t t r i b u t e t o M e a s u r e t o a l l o w c o n v e r s i o n
l o g i c a n d a g g r e g a t i o n .
e ) I n t h e E x p r e s s i o n E d i t o r , j u s t a d d t h e c o l u m n t o b e c o n v e r t e d
( F O R C U R A M ) .
f) S w i t c h t o t a b A d v a n c e d t o d e n e t h e c u r r e n c y c o n v e r s i o n r u l e . S e t t h e
t y p e t o A m o u n t w i t h C u r r e n c y a n d c h o o s e E n a b l e f o r C o n v e r s i o n .
g ) L e f t - c l i c k o n t h e v a l u e - h e l p b u t t o n n e x t t o i n p u t e l d C u r r e n c y ,
c h o o s e C o l u m n a n d a s s i g n t h e c o l u m n w i t h t h e s o u r c e c u r r e n c y c o d e
( F O R C U R K E Y ) .
h ) E n t e r T a r g e t C u r r e n c y “ U S D ” a n d E x c h a n g e T y p e “ M ” . F o r C o n v e r s i o n
D a t e a s s i g n c o l u m n O D E R _ D A T E . F i n a l l y S e t S c h e m a f o r C o n v e r s i o n
t o S F L I G H T a n d C l i e n t f o r C u r r e n c y C o n v e r s i o n t o D y n a m i c C l i e n .t
i) F i n a l l y , c h o o s e C a l c u l a t e b e f o r e A g g r e g a t i o n a n d s e t t h e A g g r e g a t i o n
t y p e t o S U M
. T h e n c l o s e t h e d e n i t i o n o f t h e c a l c u l a t e d c o l u m n b y
c l i c k i n g o n O K
.
6 . I n t h e S e m a n t i c s o f t h e v i e w , d e c l a r e t h e c a l c u l a t e d c o l u m n P A Y S U M a n d t h e
c u r r e n c y a m o u n t F O R C U R A M t o b e o f t y p e M e a s u r e a n d a l l o t h e r c o l u m n s
t o b e o f t y p e A t t r i b u t e .
a ) I n t h e S c e n a r i o w i n d o w o n t h e l e f t , c l i c k o n S e m a n t i c s .
b ) O n t h e l i s t o f c o l u m n s e d i t t h e t y p e o f t h e c o l u m n s .
7 . B a c k i n t h e o f t h e v i e w , h i d e a l l c o l u m n s f r o m t h e v i e w ’ s o u t p u t t h a t a r e o n l y
n e e d e d a s i n p u t f o r t h e c u r r e n c y c o n v e r s i o n .
a ) G o b a c k t o t h e L o g i c a l J o i n o f t h e v i e w . I n t h e O u t p u t w i n d o w , d o u b l e
c l i c k o n t h e c o l u m n . I n t h e P r o p e r t i e s w i n d o w b e l o w , c h a n g e t h e v a l u e
o f p r o p e r t y H i d d e n f r o m F a l s e t o T r u e .
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 7 1
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 187/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
8 . S a v e a n d A c t i v a t e y o u r v i e w .
a ) O n t h e t o o l b a r w i t h t h e n a m e o f t h e v i e w , c h o o s e b u t t o n S a v e a n d
A c t i v a t e . P a y a t t e n t i o n t o t h e J o b L o g w i n d o w o n t h e b o t t o m .
T a s k 3 : U s e th e S A P H A N A V ie w in a n a t iv e S Q L S e le c t
E d it y o u r p ro g ra m . C o p y th e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o
s u b r o u t i n e g e t _ d a t a _ s o lu tio n . I n s u b r o u t i n e g e t _ d a t a _ s o l u t i o n . R e p l a c e t h e t w o
S E L E C T s , th e n e s te d L O O P s , th e c u r r e n c y c o n v e r s i o n a n d t h e a g g r e g a t i o n b y
j u s t o n e s e le c t fro m y o u r a n a ly tic v i e w .
1 . C o p y t h e s o u r c e c o d e o f s u b r o u t i n e g e t _ d a t a _ t e m p l a t e t o s u b r o u t i n e
g e t _ d a t a _ s o l u t i o n
a ) U s e C o p y & P a s t e - f u n c tio n o f t h e A B A P E d i t o r .
2 . I n s u b r o u t i n e g e t _ d a ta _ s o lu ti o n , i m p l e m e n t a n A D B C c a l l o f a n a t i v e S Q L
S E L E C T th a t re a d s d a ta f r o m th e v i e w y o u j u s t c r e a t e d . M a k e t h e s e l e c t r e a d
i n t o d a t a o b j e c t s c t_ c u s to m e r s d i r e c t l y .
a ) S e e s o u rc e c o d e e x tra c t f ro m m o d e l s o l u t i o n .
3 . A c t i v a t e a n d t e s t y o u r p r o g r a m . M a k e s u r e t h e t w o s u b r o u t i n e s d e l i v e r
e x a c t l y t h e s a m e d a t a .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
4 . P e rfo rm a R u n t i m e M e a s u r e m e n t a n d Q u a n t i f y t h e i m p r o v e m e n t y o u
a c h i e v e d .
a ) C o m p l e t e t h i s s t e p a s y o u l e a r n e d t o d o i n p r e v i o u s c l a s s e s .
R e s u l t
S o u r c e c o d e e x t r a c t f r o m m o d e l s o l u t i o n
( P r o g r a m Y H A 4 0 0 _ C R E A T E _ H A N A _ V I E W _ S 1 )
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ t e m p l a t e
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ t e m p l a t e C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* D e c l a r a t i o n s
* * * * * * * * * * * * * * * *
* T y p e s f o r t a r g e t f i e l d s
C o n t i n u e d o n n e x t p a g e
1 7 2 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 188/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
T Y P E S : B E G I N O F l t y _ s _ c u s t ,
i d T Y P E s c u s t o m - i d ,
n a m e T Y P E s c u s t o m - n a m e ,
p o s t c o d e T Y P E s c u s t o m - p o s t c o d e ,
c i t y T Y P E s c u s t o m - c i t y ,
c o u n t r y T Y P E s c u s t o m - c o u n t r y ,
E N D O F l t y _ s _ c u s t .
T Y P E S : B E G I N O F l t y _ s _ b o o k ,
c u s t o m i d T Y P E s b o o k - c u s t o m i d ,
o r d e r _ d a t e T Y P E s b o o k - o r d e r _ d a t e ,
f o r c u r a m T Y P E s b o o k - f o r c u r a m ,
f o r c u r k e y T Y P E s b o o k - f o r c u r k e y ,
E N D O F l t y _ s _ b o o k .
* W o r k A r e a f o r R e s u l t
D A T A l s _ c u s t o m e r L I K E L I N E O F c t _ c u s t o m e r s .
* T a r g e t s f o r S e l e c t
D A T A : l t _ s c u s t o m T Y P E S O R T E D T A B L E O F l t y _ s _ c u s t W I T H N O N - U N I Q U E K E Y i d ,
l s _ s c u s t o m T Y P E l t y _ s _ c u s t ,
l t _ s b o o k T Y P E S O R T E D T A B L E O F l t y _ s _ b o o k W I T H N O N - U N I Q U E K E Y c u s t o m i d ,
l s _ s b o o k T Y P E l t y _ s _ b o o k .
* h e l p v a r i a b l e s
D A T A l v _ a m n t _ c o n v T Y P E p L E N G T H 1 6 D E C I M A L S 4 .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
S E L E C T i d n a m e p o s t c o d e c i t y c o u n t r y
F R O M s c u s t o m
C O N N E C T I O N ( c _ c o n )
I N T O T A B L E l t _ s c u s t o m
O R D E R B Y i d .
S E L E C T c u s t o m i d o r d e r _ d a t e f o r c u r a m f o r c u r k e y
F R O M s b o o k
C O N N E C T I O N ( c _ c o n )
I N T O T A B L E l t _ s b o o k
W H E R E c a n c e l l e d = s p a c e
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 7 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 189/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
O R D E R B Y c u s t o m i d .
L O O P A T l t _ s c u s t o m I N T O l s _ s c u s t o m .
l s _ c u s t o m e r - i d = l s _ s c u s t o m - i d .
l s _ c u s t o m e r - n a m e = l s _ s c u s t o m - n a m e .
l s _ c u s t o m e r - p o s t c o d e = l s _ s c u s t o m - p o s t c o d e .
l s _ c u s t o m e r - c i t y = l s _ s c u s t o m - c i t y .
l s _ c u s t o m e r - c o u n t r y = l s _ s c u s t o m - c o u n t r y .
C L E A R l s _ c u s t o m e r - p a y s u m .
L O O P A T l t _ s b o o k I N T O l s _ s b o o k
W H E R E c u s t o m i d = l s _ s c u s t o m - i d .
l v _ a m n t _ c o n v = l s _ s b o o k - f o r c u r a m .
C A L L F U N C T I O N ' C O N V E R T _ T O _ L O C A L _ C U R R E N C Y '
E X P O R T I N G
d a t e = l s _ s b o o k - o r d e r _ d a t e
f o r e i g n _ a m o u n t = l v _ a m n t _ c o n v
f o r e i g n _ c u r r e n c y = l s _ s b o o k - f o r c u r k e y
l o c a l _ c u r r e n c y = ' U S D '
* T Y P E _ O F _ R A T E = ' M '
r e a d _ t c u r r = ' X '
I M P O R T I N G
l o c a l _ a m o u n t = l v _ a m n t _ c o n v
E X C E P T I O N S
n o _ r a t e _ f o u n d = 1
o v e r f l o w = 2
n o _ f a c t o r s _ f o u n d = 3
n o _ s p r e a d _ f o u n d = 4
d e r i v e d _ 2 _ t i m e s = 5 .
I F s y - s u b r c < > 0 .
M E S S A G E ' C u r r e n c y c o n v e r s i o n f a i l e d ' T Y P E ' E ' .
E N D I F .
l s _ c u s t o m e r - p a y s u m = l s _ c u s t o m e r - p a y s u m + l v _ a m n t _ c o n v .
E N D L O O P .
C o n t i n u e d o n n e x t p a g e
1 7 4 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 190/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
E N D F O R M . "
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
* & F o r m g e t _ d a t a _ s o l u t i o n
* & - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
F O R M g e t _ d a t a _ s o l u t i o n C H A N G I N G c t _ c u s t o m e r s T Y P E t y _ t _ c u s t o m e r s .
* A D B C O b j e c t s a n d v a r i a b l e s
D A T A : l o _ c o n T Y P E R E F T O c l _ s q l _ c o n n e c t i o n ,
l o _ s q l T Y P E R E F T O c l _ s q l _ s t a t e m e n t ,
l o _ r e s u l t T Y P E R E F T O c l _ s q l _ r e s u l t _ s e t ,
l v _ s q l T Y P E s t r i n g ,
l r _ d a t a T Y P E R E F T O d a t a .
* E c e p t i o n h a n d l i n g
D A T A : l x _ s q l _ e x c T Y P E R E F T O c x _ s q l _ e x c e p t i o n ,
l v _ t e x t T Y P E s t r i n g .
* P r o c e s s i n g
* * * * * * * * * * * * * * * * *
C L E A R c t _ c u s t o m e r s .
T R Y .
* G e t s e c o n d a r y D B C o n n e c t i o n
l o _ c o n = c l _ s q l _ c o n n e c t i o n = > g e t _ c o n n e c t i o n ( c _ c o n ) .
* C r e a t e s t a t e m e n t
C R E A T E O B J E C T l o _ s q l
E X P O R T I N G
c o n _ r e f = l o _ c o n .
* c r e a t e S Q L s t a t e m e n t
C O N C A T E N A T E ` S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , P A Y S U M `
` F R O M _ S Y S _ B I C . " y h a 4 0 0 . s o l u t i o n / A N _ C U S T _ W I T H _ P A Y S U M " `
` W H E R E M A N D T = `
s y - m a n d t
' O R D E R B Y M A N D T , I D '
I N T O l v _ s q l
S E P A R A T E D B Y s p a c e .
* A l t e r n a t i v e : U s e s t r i n g t e m p l a t e s a n d s t r i n g e x p r e s s i o n s
* l v _ s q l = | S E L E C T I D , N A M E , P O S T C O D E , C I T Y , C O U N T R Y , P A Y S U M M | & &
* | F R O M _ S Y S _ B I C . " y h a 4 0 0 . s o l u t i o n / A N _ C U S T _ W I T H _ P A Y S U M | & &
C o n t i n u e d o n n e x t p a g e
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 7 5
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 191/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it 5 : C r e a tin g A n a ly tic a l V ie w H A 4 0 0
* | W H E R E M A N D T = { s y - m a n d t } | & &
* | O R D E R B Y M A N D T , I D | .
* E x e c u t e Q u e r y
l o _ r e s u l t = l o _ s q l - > e x e c u t e _ q u e r y ( l v _ s q l ) .
* R e a d r e s u l t i n t o i n t e r n a l T a b l e
G E T R E F E R E N C E O F c t _ c u s t o m e r s I N T O l r _ d a t a .
l o _ r e s u l t - > s e t _ p a r a m _ t a b l e ( l r _ d a t a ) .
l o _ r e s u l t - > n e x t _ p a c k a g e ( ) .
l o _ r e s u l t - > c l o s e ( ) .
C A T C H c x _ s q l _ e x c e p t i o n I N T O l x _ s q l _ e x c . " E x c e p t i o n C l a s s f o r S Q L E r r o r
l v _ t e x t = l x _ s q l _ e x c - > g e t _ t e x t ( ) .
M E S S A G E l v _ t e x t T Y P E ' E ' .
E N D T R Y .
E N D F O R M . "
1 7 6 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 192/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 L e s s o n : C r e a tin g A n a ly tic V ie w
L e s s o n S u m m a r y
Y o u s h o u l d n o w b e a b l e t o :
• C r e a t e a n A n a l y ti c v ie w
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 7 7
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 193/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
U n it S u m m a r y H A 4 0 0
U n it S u m m a r y
Y o u s h o u ld n o w b e a b l e t o :
• C r e a t e a n A n a l y ti c v ie w
1 7 8 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 194/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 195/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 196/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
H A 4 0 0 C o u rs e S u m m a ry
C o u r s e S u m m a r y
Y o u s h o u ld n o w b e a b l e t o :
• U n d e rs ta n d th e T e c h n ic a l S A P H A N A c o n c e p ts
• U n d e r s ta n d O p tim iz a tio n o f c la s s ic a l A B A P in H A N A C o n t e x t
• D e s c r i b e t h e u s a g e o f A n a l y s i s T o o l s ( R u n t i m e A n a l y s i s , C o d e I n s p e c t o r ,
S Q L T r a c e )
• U n d e r s t a n d S Q L P e r f o r m a n c e R u l e s o f A B A P f o r H A N A
• E x p la in Im p le m e n tin g A B A P re p o rt o n H A N A u s i n g A D B C ( A B A P D a t a
B a s e C o n n e c t i v i t y )
• E x p la in C o n s u m in g H A N A v i e w s i n A B A P
• E x p la in C re a tin g H A N A v i e w s a n d C o n s u m i n g i n A B A P
2 0 1 3 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 1 7 9
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 197/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
C o u rs e S u m m a r y H A 4 0 0
1 8 0 © 2 0 1 3 S A P A G . A ll r ig h ts r e s e r v e d . 2 0 1 3
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 198/199
5/20/2018 Ha400-AbapProgrammingon SapHana-slidepdf.com
F e e d b a c k
S A P A G h a s m a d e e v e r y e f f o r t i n t h e p r e p a r a t i o n o f t h i s c o u r s e t o e n s u r e t h e
a c c u ra c y a n d c o m p l e t e n e s s o f t h e m a t e r i a l s . I f y o u h a v e a n y c o r r e c t i o n s o r
s u g g e s tio n s f o r i m p r o v e m e n t , p l e a s e r e c o r d t h e m i n t h e a p p r o p r i a t e p l a c e i n t h e
c o u r se e v a l u a t i o n .
http://slidepdf.com/reader/full/ha400-abap-programming-on-sap-hana 199/199