2017-09-16 28 views
1

我已經使用groovy腳本創建了數千個映射,但我無法運行它們。如何使用groovy腳本創建odi映射的場景

我可以迭代映射,但現在想用groovy腳本來運行映射。 如何創建映射場景,然後使用groovy腳本運行場景 ?

+1

這聽起來像是你可以通過使用搜索引擎進行搜索來解決的問題。 – admcfajn

回答

1
//Created by DI Studio 
//Created by DI Studio 
//Created by DI Studio 
//Created by DI Studio 

//Created by DI Studio 
//Created by DI Studio 
//Created by DI Studio 
import oracle.odi.domain.project.finder.IOdiProjectFinder; 
import oracle.odi.domain.model.finder.IOdiDataStoreFinder; 
import oracle.odi.domain.project.finder.IOdiFolderFinder; 
import oracle.odi.domain.mapping.finder.IMappingFinder; 
import oracle.odi.domain.model.OdiDataStore; 
import oracle.odi.domain.model.OdiModel; 
import oracle.odi.domain.model.finder.IOdiModelFinder; 
import oracle.odi.core.persistence.transaction.support.DefaultTransactionDefinition; 
import oracle.odi.generation.support.OdiScenarioGeneratorImpl; 
import oracle.odi.generation.IOdiScenarioGenerator; 
import oracle.odi.domain.runtime.scenario.OdiScenario; 
import oracle.odi.domain.mapping.Mapping; 
import oracle.odi.domain.mapping.finder.IMappingFinder; 
import oracle.odi.domain.runtime.scenario.finder.IOdiScenarioFinder; 
import oracle.odi.domain.project.OdiProject; 



    //txnDef = new DefaultTransactionDefinition() 
    //tm = odiInstance.getTransactionManager() 
    //tme = odiInstance.getTransactionalEntityManager() 
    //txnStatus = tm.getTransaction(txnDef) 
    //pf = (IOdiProjectFinder)tme.getFinder(OdiProject.class) 
    //ff = (IOdiFolderFinder)tme.getFinder(OdiFolder.class) 

//Variables 
//projectName = "Project Name" 
//folderName = "Folder Name" 
//sourcemodelName = "Source Name" 
//targetmodelName = "Target name" 
//find project and the folder 

/* 
def mappingList = ((IMappingFinder) odiInstance.getTransactionalEntityManager().getFinder(Mapping.class)).findByProject("STOO3", "STO3") 
ms=mapplingList.iterator() 
while(ms.hasNext()){ 
println ms.getName() 
} 

*/ 

txnDef = new DefaultTransactionDefinition() 
tm = odiInstance.getTransactionManager() 
tme = odiInstance.getTransactionalEntityManager() 
txnStatus = tm.getTransaction(txnDef) 
def fm = ((IMappingFinder) tme.getFinder(Mapping.class))   // shorcut to Find Mapping 
def mappingList = fm.findAll().findAll{w -> w.getProject().getCode() == 'CUSTDBN'} 
//def mappingList = ((IMappingFinder) odiInstance.getTransactionalEntityManager().getFinder(Mapping.class)).findByProject("SOCAIRO", "STO") 
if (mappingList == null){ 
    println "Map is null" 
} 
ms=mappingList.iterator() 
while(ms.hasNext()){ 
       ms_i = ms.next() 
       println ms_i.getName() 
       scenName = ms_i.getName(); 

       //IIOdiScenarioGenerator gene = new OdiScenarioGeneratorImpl((odiInstance) 
       //OdiScenario newScen = gene.generateScenario(ms_i, scenName,newVersion)} 
       //odiInstance.getTransactionalEntityManager().persist(ms_i); 
       //OdiScenarioGenerator gene = new OdiScenarioGeneratorImpl((odiInstance) 
      //gene.generateScenario(ms_i, scenName,"001") 

      stxnDef = new DefaultTransactionDefinition() 
      stm = odiInstance.getTransactionManager() 
      stme = odiInstance.getTransactionalEntityManager() 
      stxnStatus = stm.getTransaction(stxnDef) 

      OdiScenario sc = ((IOdiScenarioFinder)  stme.getFinder(OdiScenario.class)).findLatestByName(scenName) 
      if (sc != null){ 
       println "Scenario already exist" 
       println sc 
      } 
      IOdiScenarioGenerator gene = new OdiScenarioGeneratorImpl(odiInstance); 
      OdiScenario newScen = gene.generateScenario(ms_i, scenName, "001") 
      println newScen 
      //tme.persist(newScen) 
      stm.commit(stxnStatus) 
      println "Created" 
      //odiInstance.close() 

      } 
tm.commit(txnStatus) 

//println ((IMappingFinder) odiInstance.getTransactionalEntityManager().getFinder(Mapping.class)).findByProject("STOO3", "STO3") 

       //ms_i.validate() 
       //ms_i.submit()