Скажем, у меня есть строка - "D: \ ApEx_Schema \ Functions \ new.sql @@ \ main \ ONEVIEW_Integration \ 3" Мне нужно извлечь следующую информацию в переменные diff - имя файла - путь к файлу - и версию (котораяявляется последним символом строки)
Пожалуйста, помогите с помощью задач ANT
===================================== Я пытаюсь прочитать текстовый файл, который содержит данные, указанные ниже: -
.\ApEx_Schema\Functions\new.sql@@\main\ONEVIEW_Integration\3
.\ApEx_Schema\Functions\Functions.sql@@\main\ONEVIEW_Integration\3
.\ApEx_Schema\Indexes\Indexes.sql@@\main\ONEVIEW_Integration\2
и пытаюсь собрать имя файла, его путь и деталии его версия и обновление то же самое в БД с помощью задачи SQL.Хотя мой build.xml не выдает желаемого результата.Любые предложения и мнения !!!
Мой файл Build.xml выглядит как - ============== START ===========================
<description>
obiee copy files build file
</description>
<replace file="D:\buildFRIDAY\database.txt" token=".\" value="D:\"/>
<loadfile property="src" srcFile="D:\buildFRIDAY\database.txt"/>
<path id="antclasspath">
<fileset dir="D:\OraHome_1\oracledi\drivers">
<include name="ojdbc14.jar"/>
</fileset>
</path>
<for list="${src}" param="detls" delimiter="${line.separator}">
<sequential>
<taskdef resource="net/sf/antcontrib/antcontrib.properties"/>
<propertyregex property="path" input="@{detls}"
regexp="(.*)\\.*@@" select="\1" />
<propertyregex property="file" input="@{detls}"
regexp=".*\\(.*)@@" select="\1" />
<propertyregex property="version" input="@{detls}"
regexp=".*\\(.*)" select="\1" />
<echo>
Input: @{detls}
Path: ${path}
File: ${file}
Version: ${version}
</echo>
<if>
<matches string="@{detls}" pattern=".sql" />
<then>
</then>
</if>
<if>
<matches string="@{detls}" pattern="[0-9]" />
<then>
<sql
driver="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@172.16.88.68:1521:rdev"
userid="rapid"
password="rapid"
print="yes"
classpathref="antclasspath">
Insert into ROLTA_PATCH_FILE_APP_TAB (PATCH_NO,FILE_NAME,FILE_PATH,FILE_VERSION,APPLIED_DATE,STATUS) values ('3.2.12',"@{detls}",'D:\ApEx_Schema\Functions\Functions.sql','3',to_date('11-MAR-11','DD-MON-RR'),'Y');
Insert into ROLTA_PATCH_TAB (PATCH_NO,PATCH_NAME,APPL_NAME,APPLIED_DATE) values ('3.2.12','2.1.11','@{detls}',to_date('11-MAR-11','DD-MON-RR'));
</sql>
</then>
</if>
</sequential>
</for>
============== END ===========================