BIEE 12c 批量替换catalog主题名

有的时候,我们需要修改rpd展现层的主题名。虽然改完名称之后,会自动创建旧名称的别名,以便不影响现有使用该主题的分析。

但是这样有的时候还是会有一些小问题,所以完美的解决办法是同时也将现有分析的主题名一并修改。

如果分析少的话,直接在具体分析的高级页面修改即可。但是如果分析多了,或者你根本不知道有哪些分析使用了该主题应该怎么办呢?


我们可以使用runcat.sh来批量替换catalog对象(不止是分析)的主题名、字段名、表名等。


runcat.sh位于$FMW/user_projects/domains/bi/bitools/bin目录下

执行./runcat.sh -help可以查看帮助。如果需要查看具体某个命令的帮助,可以

./runcat.sh -cmd replace -help   

replace就是我们此次需要使用的命令,该命令有两种工作模式:online和offline,区别是offline不受对象权限控制。

replace可以完成文本、主题域、表、字段、公式的替换

示例如下:

./runcat.sh -cmd replace -online http://bjkjy-bi-devbiee01.bjkjy.com:8706/analytics/saw.dll -credentials user.txt -folderFromFile folder.txt -inputFile replaceCmds.xml


user.txt的内容如下:

login=weblogic
pwd=admin123


folder.txt内容如下:

/shared/groups/misc
/shared/groups/_filters

注:你还可以使用-skipFolderFromFile参数来排除某些目录,具体请参见帮助


replaceCmds.xml的内容如下:



   
   
   
   
   
   




执行成功之后会打印替换掉的对象列表。


不过需要注意的是,这个替换不是完全匹配,什么意思?

举个例子,比如你有一个主题叫“ABC”你想把他替换成"BI_ABC",你按照上面执行了一次命令,成功替换成"BI_ABC"。

但是你不小心又执行了一次,这次的结果就是会把BI_ABC替换成BI_BI_ABC。因为只匹配了ABC,而不是整个主题名,所以请注意这一点。


如果想使用全量匹配应该应该怎么办?

查看分析的xml文件找到主题域名部分:

subjectArea=""paint""

可以看到完成的主题名前后有" (引号的转义符)

那么,如果我们要实现完全匹配,则需要按如下的方式编写:



   


注意:newValue前后也要添加"


另外,还可以使用正则表达式来进行查找替换,对

例如:

replaceCmds.xml中如下:



   






最后,11g同样可以使用runcat.sh


你可能感兴趣的:(BIEE,12c)