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

Для чего INVERTED-DATE?



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


Age: 44
Joined: 22 Sep 2009
Posts: 30

PostPosted: Thu Dec 16, 2010 11:12 am    Post subject: Для чего INVERTED-DATE? Reply with quote

Добрый день, колеги.
Может кто-нибудь объяснить логику приведенного кода?
Code:
  CONVERT DATE exc_date INTO INVERTED-DATE datc.
....
    SELECT        * FROM  tcurf CLIENT SPECIFIED
           WHERE  kurst       = exc_type
           AND    fcurr       = for_curr
           AND    tcurr       = loc_curr
           AND    gdatu      GE datc
           AND    mandt       = mandt
           ORDER BY PRIMARY KEY.


Для чего надо было конвертить дату и в запросе указывать GE в запросе? Ведь если, например, начальная дата - 20090101(exc_date), то после конвертации - 79909898 (datc). Запрос не найдет никаих записей. Или я не прав?
Back to top
View user's profile Send private message
John Doe
Модератор
Модератор


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

PostPosted: Thu Dec 16, 2010 11:47 am    Post subject: Reply with quote

В tcurf все даты инвентированы.
Дата 20090101 как бы показывает нам, что через 79909898 чего-то там придет пипец. Вот такое вот ненаучное объяснение Cool

И вообще это все от праотцов.
Quote:
These statements are obsolete and are only available to ensure compatibility with Releases prior to 4.6 and 6.10. The statements may appear in older programs but should no longer be used.
Back to top
View user's profile Send private message Blog
Anton_bs
Участник
Участник


Age: 44
Joined: 22 Sep 2009
Posts: 30

PostPosted: Thu Dec 16, 2010 11:54 am    Post subject: Reply with quote

Тогда приведу другой код
Code:
    SELECT        * FROM  tcurf CLIENT SPECIFIED
           WHERE  kurst       = exc_type
           AND    fcurr       = for_curr
           AND    tcurr       = loc_curr
           AND    gdatu      GE datc
           AND    mandt       = mandt
          ORDER BY PRIMARY KEY.
      EXIT.
    ENDSELECT.

На сколько я понял он должен выбрать последний (по дате) курс.
Правильно?
Back to top
View user's profile Send private message
Anton_bs
Участник
Участник


Age: 44
Joined: 22 Sep 2009
Posts: 30

PostPosted: Thu Dec 16, 2010 12:03 pm    Post subject: Reply with quote

Как то он каряво работает. В таблице есть такие записи

условие такое exc_type = 'M', for_curr = 'UAH', loc_curr = 'USD', datc = '79909098'(т.е. "перевернутое" 20090901).

Запрос ничего не возвращает - sy-subrc = 4
Back to top
View user's profile Send private message
John Doe
Модератор
Модератор


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

PostPosted: Thu Dec 16, 2010 12:27 pm    Post subject: Reply with quote

Он должен найти последний действительный на дату курс. То есть на 01.09.2009 или раньше.
Поскольку запись такая в табличке у вас присутствует, есть вариант посмотреть на переменную mandt в условии.
Back to top
View user's profile Send private message Blog
Anton_bs
Участник
Участник


Age: 44
Joined: 22 Sep 2009
Posts: 30

PostPosted: Thu Dec 16, 2010 12:55 pm    Post subject: Reply with quote

Спасибо, разобрался.
Quote:
То есть на 01.09.2009 или раньше.

З.Ы.
Прошу прощения, что сразу не указал мандант. Но он такой как надо
Back to top
View user's profile Send private message
Удав
Гуру
Гуру


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

PostPosted: Thu Dec 16, 2010 3:23 pm    Post subject: Re: Для чего INVERTED-DATE? Reply with quote

Anton_bs wrote:
Для чего надо было конвертить дату и в запросе указывать GE в запросе?

Вообще лучше в случае с курсами не лезть напрямую в таблицы, а воспользоваться стандартными функциями

_________________
С уважением,
Удав.
Back to top
View user's profile Send private message
Anton_bs
Участник
Участник


Age: 44
Joined: 22 Sep 2009
Posts: 30

PostPosted: Thu Dec 16, 2010 5:23 pm    Post subject: Reply with quote

это кусок стандартного кода. вот ковырял деббагером и нашел такое чудо
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.