Использование Groovy в ODI для установки подписчика для источника данных - PullRequest
1 голос
/ 26 февраля 2020

У нас есть требование массового изменения подписчика на многих сопоставлениях, но мне трудно построить правильные вызовы методов. Я перебираю свой список сопоставлений, но не уверен, как изменить подписчика для каждого сопоставления. У меня есть такая структура кода в моем Groovy сценарии:

//Created with ODI Studio

import groovy.swing.SwingBuilder

import java.awt.FlowLayout as FL
import javax.swing.DefaultComboBoxModel
import javax.swing.BoxLayout as BXL

import oracle.odi.domain.project.finder.IOdiProjectFinder;
import oracle.odi.domain.project.OdiProject;
import oracle.odi.domain.adapter.project.IKnowledgeModule.ProcessingType;
import oracle.odi.domain.project.finder.IOdiFolderFinder;
import oracle.odi.domain.project.OdiFolder;
import oracle.odi.domain.mapping.finder.IMappingFinder;
import oracle.odi.domain.mapping.Mapping;
import oracle.odi.domain.mapping.component.Dataset;
import oracle.odi.domain.mapping.component.DatastoreComponent;
import oracle.odi.interfaces.interactive.support.InteractiveInterfaceHelperWithActions;
import oracle.odi.interfaces.interactive.IInteractiveInterfaceHelperWithActions;
import oracle.odi.core.persistence.transaction.ITransactionStatus;
import oracle.odi.core.persistence.transaction.support.DefaultTransactionDefinition;
import oracle.odi.domain.mapping.physical.MapPhysicalNode;

//**********************************************************

// Careful, this is the project CODE, not the project name (all caps, no spaces)
myProject = "PROJECT"  // CODE of the ODI project where subscribers have to be replaced 
myFolder = "TEST FOLDER" // Folder where subscribers have to be replaced 
NewSubscriberName="TEST_SUBSCRIBER"  // Name of the new Subscriber that will replace the old one
MappingNamePattern="MAP_"  // Any part of the mapping name, if there is a pattern. Leave blank to process all mappings. 
// Example for patterns: "LOAD_" will process mapping LOAD_CUSTOMERS and PRELOAD_CUSTOMER but not LOADER_PRECURSOR

//--------------------------------------
// Build the list of available Folders

def getFoldersList(projectCode){
  folders = []
  foldersList = ff.findByProject(projectCode)

  for (folder in foldersList){
    folders.add(folder.getName())
    //println(folder.getName())
  }

  folders.sort()

  return folders
}

//-------------------------------------------------------------
// Main processing 
// First, retrieve the ODI studio connection to the repository
txnDef = new DefaultTransactionDefinition();
tm = odiInstance.getTransactionManager();
tme = odiInstance.getTransactionalEntityManager()
txnStatus = tm.getTransaction(txnDef);

// Create a few shortcuts for the finders
pf = (IOdiProjectFinder)odiInstance.getTransactionalEntityManager().getFinder(OdiProject.class);
ff = (IOdiFolderFinder)odiInstance.getTransactionalEntityManager().getFinder(OdiFolder.class);
mapf = (IMappingFinder) odiInstance.getTransactionalEntityManager().getFinder(Mapping.class); 

// Locate the folder in the project
OdiFolder folder = null;
folderColl = ff.findByName(myFolder, myProject)
if (folderColl.size() == 1)
  folder = folderColl.iterator().next();

if (folder == null) {
   println("*** Could not find folder named\""+myFolder+"\"")
   exit
}

//--------------------------------------
// Retrieve all mappings in that folder
def OdiMappingsList = mapf.findByProject(myProject, folder.getFolderId())
println("*** Processing mappings for Project \""+myProject+"\", Folder \"" + myFolder+"\"")

//--------------------------------------
// For each mapping, do the folowing:
// - print mapping name
// - check if mapping name matched search string. If not, print 'no action' and get to the next mapping
// - if we have a name match, replace Subscriber with the new value.

for (map in OdiMappingsList){
    println("*******\nMapping: " + map.getName())
    bSubscriberChanged=false        
    // Make sure that the mapping matches the names we are looking for 
    if (map.getName().contains(MappingNamePattern)){
        // Set the subscriber
        sources = map.getSources()
        for (sourceDS in sources) {
           --- I NEED TO SET THE SUBSCRIBER HERE ---
           bSubscriberChanged=true
        }
    } else {// No match on mapping name
        println ("Skipped mapping: name does not contain \"" + MappingNamePattern +"\"")
    }
    if (bSubscriberChanged){
        // Persist the changes in the cache
        tme.persist(map);
    }
}//Mapping

// Commit the changes in the repository
tm.commit(txnStatus);

Любая помощь будет принята с благодарностью.

1 Ответ

1 голос
/ 27 февраля 2020

Вы можете получить список исходных компонентов вашего отображения, используя getSources из IMapComponentOwner (который реализован в Mapping). Эти исходные компоненты должны иметь тип DatastoreComponent , который имеет метод для установки JournalizedFiler.

Это было бы что-то вроде этого (еще не смог проверить это):

srcComps = map.getSources()
srcComps.each() { srcComp ->
    if (srcComp.isJournalized()) {
        srcComp.setJournalizedFilter("JRN_SUBSCRIBER = '"+NewSubscriberName+"'")
    }
}

Обратите внимание, что этот код изменяет фильтр только в том случае, если компонент настроен на журналирование.

Если текущие журнализированные фильтры более сложны, чем эти (например, включают фильтр даты), вам необходимо использовать getJournalizedFilter () и проанализируйте результат, чтобы заменить имя подписчика, а не перезаписывать весь фильтр.

...