SAP R/3 форум ABAP консультантов
Russian ABAP Developer's Club

Home - FAQ - Search - Memberlist - Usergroups - Profile - Log in to check your private messages - Register - Log in - English
Blogs - Weblogs News

очередной вопрос про select'Ы



 
Post new topic   Reply to topic    Russian ABAP Developer's Club Forum Index -> ABAP
View previous topic :: View next topic  
Author Message
GirlSmile
Участник
Участник



Joined: 25 Jan 2009
Posts: 9

PostPosted: Wed Feb 04, 2009 9:17 pm    Post subject: очередной вопрос про select'Ы Reply with quote

Доброго времени суток!
Мучаюсь вторые суткиCrying or Very sad
Пожалуйста, помогите с правильным выбором select'ов
(под * подписала то, что хотелось бы сделать ... )

Code:
type-pools: slis.

tables: ekko, ekpo.

data:
      begin of tab,
      ebelp like ekpo-ebelp,
      matnr like ekpo-matnr,
      werks like ekpo-werks,
      netpr like ekpo-netpr,
      menge like ekpo-menge,
      netwr like ekpo-netwr,
      mblnr like mseg-mblnr,
      ebeln like mseg-ebeln,   
      end of tab,
     
      begin of tab_bedat occurs 0,
      bedat like ekko-bedat,
      end of tab_bedat,
         
      begin of tab_mblnr occurs 0,
       mblnr like mseg-mblnr,
       mjahr like mseg-mjahr,
       ebeln like mseg-ebeln,
       smbln like mseg-smbln,
       end of tab_mblnr.

 data: tab_1 like tab occurs 0 with header line.
 
 data: it_fieldcat type slis_fieldcat_alv occurs 0 with header line,
       gs_header type slis_listheader,
       gt_header type slis_t_listheader.

 selection-screen begin of block bl1 with frame.
   parameters: s_ebeln like mseg-ebeln.
   select-options: s_bedat for ekko-bedat.
 selection-screen end of block bl1.

 start-of-selection.
* позиции по ekpo
 select ebelp matnr werks netwr menge netpr
   into corresponding fields of table tab_1
   from ekpo.
   
* для вывода номера документа мат-ла по номеру заказа
* (очень сомневаюсь, что правильно)
  select distinct mblnr
  from mseg
  into table tab_mblnr
  where ebeln eq s_ebeln
  and mseg~smbln eq space.
                 
loop at tab_mblnr. 
* проверка на сторно   
select single smbln into tab_mblnr-mblnr " номер документа мат
   from mseg
  where sjahr eq tab_mblnr-mjahr " год документа мат
  and smbln eq tab_mblnr-mblnr. 
* код возврата
  if sy-subrc eq 0.
  delete tab_mblnr
  where mblnr eq tab_mblnr-mblnr
  and mjahr eq tab_mblnr-mjahr.
  clear tab_mblnr.
  continue.
  endif.
  move-corresponding tab_mblnr to tab_1.
endloop.

* попытка присобачить дату из ekko   
 loop at tab_bedat.
   select single bedat
   into tab_bedat
   from ekko.     
   move-corresponding tab_bedat to tab_1. 
 endloop.
 
 end-of-selection.

  call function 'ZUNI_FIELDCAT_MERGE'
  exporting
        i_callback_program = sy-repid
        i_internal_tabname = 'TAB_1'
        i_inclname = sy-repid
      changing
        et_reuse_fcat = it_fieldcat[].
    perform change_fieldcat.
  call function 'REUSE_ALV_GRID_DISPLAY'
      exporting
        i_callback_program = sy-repid
        i_callback_top_of_page = 'TOP_OF_PAGE'
        i_callback_user_command = 'AT_USER_COMMAND'
        it_fieldcat = it_fieldcat[]
        tables
        t_outtab = tab_1.

  form change_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'BEDAT'.
  it_fieldcat-ref_tabname    = 'EKKO'.
  it_fieldcat-ref_fieldname = 'BEDAT'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'MBLNR'.
  it_fieldcat-ref_tabname    = 'MSEG'.
  it_fieldcat-ref_fieldname = 'MBLNR'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'MATNR'.
  it_fieldcat-ref_tabname    = 'EKPO'.
  it_fieldcat-ref_fieldname = 'MATNR'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'EBELP'.
  it_fieldcat-ref_tabname    = 'EKPO'.
  it_fieldcat-ref_fieldname = 'EBELP'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'WERKS'.
  it_fieldcat-ref_tabname    = 'EKPO'.
  it_fieldcat-ref_fieldname = 'WERKS'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'NETPR'.
  it_fieldcat-ref_tabname    = 'EKPO'.
  it_fieldcat-ref_fieldname = 'NETPR'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'MENGE'.
  it_fieldcat-ref_tabname    = 'EKPO'.
  it_fieldcat-ref_fieldname = 'MENGE'.
  append it_fieldcat.
  it_fieldcat-tabname   = 'TAB_1'.
  it_fieldcat-fieldname = 'NETWR'.
  it_fieldcat-ref_tabname    = 'EKPO'.
  it_fieldcat-ref_fieldname = 'NETWR'.
  append it_fieldcat.
  endform.

FORM top_of_page.

  if sy-pagno eq 0 or sy-pagno eq 1.
    clear: gt_header, gt_header[].
  gs_header-info = 'Тест_1'.
  gs_header-typ = 'H'.
  append gs_header to gt_header.
  clear gs_header.

  call function 'REUSE_ALV_COMMENTARY_WRITE'
  exporting it_list_commentary = gt_header.
  else.
  perform top_of_page.
  endif.
  endform.
Back to top
View user's profile Send private message
ghost
Специалист
Специалист


Age: 37
Joined: 18 Jan 2008
Posts: 71
Location: Tashkent-Astana-Moscow

PostPosted: Thu Feb 05, 2009 9:52 am    Post subject: Reply with quote

мда Shocked советую почитать курсы по ABAP Dictionary материала много здесь отдельная ветка есть ABAP Dictionary там же FAQ ABAP Dictionary

как минимум для ekko и ekpo можно использовать join

не хилая попытка
Code:
* попытка присобачить дату из ekko   
 loop at tab_bedat.
   select single bedat
   into tab_bedat
   from ekko.     
   move-corresponding tab_bedat to tab_1.
 endloop.


и еще можно заюзать истоию заказа PO таблица EKBE
Back to top
View user's profile Send private message Send e-mail Blog
menx
Участник
Участник



Joined: 21 Nov 2008
Posts: 25
Location: СПб - Валлдорф

PostPosted: Thu Feb 05, 2009 12:00 pm    Post subject: Reply with quote

кстати чисто для информации: таблицы с header line уже давно obsolete!
Back to top
View user's profile Send private message
GirlSmile
Участник
Участник



Joined: 25 Jan 2009
Posts: 9

PostPosted: Thu Feb 05, 2009 12:44 pm    Post subject: Reply with quote

спасибо ... правда не очень помогло...

но вот что получилось
Code:

 start-of-selection.

  select mblnr
  from mseg
  into table tab_mblnr
  where ebeln eq s_ebeln.
   
 select * into corresponding fields of table tab_1
   from mseg
   inner join ekpo
   on ekpo~matnr eq mseg~matnr
   inner join ekko
   on ekko~ebeln eq mseg~ebeln
   where mseg~smbln = space.
 
loop at tab_mblnr.
* проверка на сторно
select single smbln into tab_mblnr-mblnr " номер документа мат
   from mseg
  where sjahr eq tab_mblnr-mjahr " год документа мат
  and smbln eq tab_mblnr-mblnr.
* код возврата
  if sy-subrc eq 0.
  delete tab_mblnr
  where mblnr eq tab_mblnr-mblnr
  and mjahr eq tab_mblnr-mjahr.
  clear tab_mblnr.
  continue.
  endif.
  move-corresponding tab_mblnr to tab_1.
endloop.

sort tab_1 by bedat.

 end-of-selection.


с inner join долго правда, но работает
Back to top
View user's profile Send private message
John Doe
Модератор
Модератор


Age: 46
Joined: 05 Nov 2007
Posts: 725
Location: КраснАдар

PostPosted: Thu Feb 05, 2009 1:03 pm    Post subject: Reply with quote

Простите, а что эти мертворожденные куски программы должны делать функционально?
Back to top
View user's profile Send private message Blog
ghost
Специалист
Специалист


Age: 37
Joined: 18 Jan 2008
Posts: 71
Location: Tashkent-Astana-Moscow

PostPosted: Thu Feb 05, 2009 1:19 pm    Post subject: Reply with quote

Quote:
с inner join долго правда,

вы еще удивляетесь ? Confused
Code:
select * into corresponding fields of table tab_1
   from mseg
   inner join ekpo
   on ekpo~matnr eq mseg~matnr
   inner join ekko
   on ekko~ebeln eq mseg~ebeln
   where mseg~smbln = space.
Back to top
View user's profile Send private message Send e-mail Blog
GirlSmile
Участник
Участник



Joined: 25 Jan 2009
Posts: 9

PostPosted: Thu Feb 05, 2009 1:20 pm    Post subject: Reply with quote

* выборка по номеру заказа номера документа материала..
выводится данные должны из ekko, ekpo, mseg - не сторнированные

А почему мертворожденные?
Back to top
View user's profile Send private message
John Doe
Модератор
Модератор


Age: 46
Joined: 05 Nov 2007
Posts: 725
Location: КраснАдар

PostPosted: Thu Feb 05, 2009 1:22 pm    Post subject: Reply with quote

GirlSmile wrote:
А почему мертворожденные?

Потому что так писать - просто не допустимо.
Back to top
View user's profile Send private message Blog
GirlSmile
Участник
Участник



Joined: 25 Jan 2009
Posts: 9

PostPosted: Thu Feb 05, 2009 1:36 pm    Post subject: Reply with quote

Хм ... конструкция с двумя inner join'ами была найдена именно на этом форуме. В ином случае вывести данные из трех таблиц (не объединяя ни одну позицию) ... не получается.

Буду иметь ввиду, что при рабочих программах данная конструкция не допустима.
Но в данной ситуации для человека, который имеет дело с программой две недели - это прорыв, поскольку до этого с select'ом b loop/endloop ... выводились данные только из двух таблиц.
Собственно, написано сюда было ... с вопросом... как бы это было лучше сделать) ...
Back to top
View user's profile Send private message
Удав
Гуру
Гуру


Age: 48
Joined: 25 Jan 2008
Posts: 580
Location: Москва

PostPosted: Thu Feb 05, 2009 5:59 pm    Post subject: Reply with quote

GirlSmile wrote:
* выборка по номеру заказа номера документа материала..
выводится данные должны из ekko, ekpo, mseg - не сторнированные

А почему мертворожденные?

Для таких задач SAP сделал таблицу EKBE.

А алгоритмы нахождения документов сторно можно найти с помощью поиска по словам "MSEG" и "сторно" Wink

Вот еще полезная информация по основным таблицам SAP и связям между ними

_________________
С уважением,
Удав.
Back to top
View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic    Russian ABAP Developer's Club Forum Index -> ABAP All times are GMT + 4 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


All product names are trademarks of their respective companies. SAPNET.RU websites are in no way affiliated with SAP AG.
SAP, SAP R/3, R/3 software, mySAP, ABAP, BAPI, xApps, SAP NetWeaver and any other are registered trademarks of SAP AG.
Every effort is made to ensure content integrity. Use information on this site at your own risk.