green_fr (green_fr) wrote,
green_fr
green_fr

Category:

Знатоки oracle, отзовитесь


Есть некий файл, который надо загрузить в базу данных.
В файле есть 2 различных видов записи, какая запись перед нами можно понять по первому полю файла.
Я сделал 2 таблицы и написал SQLLoader control file, который вполне прилично грузит записи по соответствующим файлам.
Проблема в том, что записи первого рода являются заголовками для серии (переменного размера) записей второго рода. Никаких данных, позволяющих провести связывание, во вторых записях нет. А связать нужно.

Первый вариант - вставлять в базу номер строки в исходном файле. Теоретически должно было бы работать, но тут у меня небольшое осложнение. Я пишу файлы не replace, а append, т.е. к моменту загрузки очередного файла в таблицах могут уже находиться строки из предыдущих файлов.
Т.е. для этого варианта мне не хватает какого-нибудь идентификатора файла (факта загрузки).

Теоретически для этого можно было бы использовать текущую дату, но по понятным причинам (2 загрузки в 1 день, загрузка ровно в полночь и т.п.) мне это не нравится.

Другой вариант - вставлять ещё и некий глобальный (в пределах одной таблицы) sequence number, позволяющий отделять группы линий, относящихся к одному файлу. Это не работает, если придёт файл только с записями первого рода.

Какой-нибудь совершенно другое решение?
Tags: rabota
Subscribe

  • Fête de la science 2016 — Jussieu & Polytechnique

    На праздник науки снова ходили в Jussieu и Ecole Polytechnique. В первом выставили как обычно десятки независимых стендов, но в добавок ещё и открыли…

  • Fête de la science 2015

    На праздник науки снова сходили в Ecole Polytechnique (вот прошлый год — 1, 2) — ребята, мне кажется, нигде не повторились! Стенд…

  • Fête de la science 2014 — LATMOS

    В LATMOS придумали на удивление грамотную (для научной лаборатории) организацию — на входе посетителей встречают специально обученные люди, выдают…

  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 6 comments