<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Insert Update Incremental Load in App Development</title>
    <link>https://community.qlik.com/t5/App-Development/Insert-Update-Incremental-Load/m-p/1543286#M39182</link>
    <description>&lt;P&gt;Hi All,&lt;/P&gt;&lt;P&gt;I have file structure such as below.&amp;nbsp; Each Folder will have a number of different files.&amp;nbsp; Currently I have a load that loops through each file in the folder to make a QVD and I want to improve this process by making an Incremental Load.&amp;nbsp; Note it is possible for files in past Months folders to change.&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am utilizing an Insert Update, incremental methodology.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="FileStrcuture.png" style="width: 560px;"&gt;&lt;img src="https://community.qlik.com/t5/image/serverpage/image-id/5806i02F507959B44626F/image-size/large?v=v2&amp;amp;px=999" role="button" title="FileStrcuture.png" alt="FileStrcuture.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I've implemented the below Incremental Script and it reduces the load from ~10 minutes to ~6 minutes but I am wondering if anyone has any suggestions on how I could optimize it to make it even faster?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;FilesHistTemp:&lt;BR /&gt;Load * inline&lt;BR /&gt;[&lt;BR /&gt;x&lt;BR /&gt;];&lt;/P&gt;&lt;P&gt;let vPeriod = Num('$(vMinPeriod)');&lt;/P&gt;&lt;P&gt;let vLastExecution = TimeStamp(QvdCreateTime('$(vHistoricalQVD)'),'YYYY-MM-DD hh:mm:ss');&lt;BR /&gt;let vThisExecution = Timestamp(Now(),'YYYY-MM-DD hh:mm:ss');&lt;/P&gt;&lt;P&gt;do while vPeriod &amp;lt; Year(Today())*100+Month(Today())&lt;/P&gt;&lt;P&gt;let vYear = Num(left(Text(vPeriod),4));&lt;BR /&gt;let vMonth = Num(right(Text(vPeriod),2));&lt;BR /&gt;let vFolder = left(Text(vPeriod),4)&amp;amp;'-'&amp;amp;right(Text(vPeriod),2);&lt;BR /&gt;let vMonthEndNum = num(date#(monthend(date#('$(vPeriod)','YYYYMM'))));&lt;/P&gt;&lt;P&gt;FOR Each vFile in filelist('$(vHistoricalPath)\$(vFolder)\$(vHistoricalFile)')&lt;/P&gt;&lt;P&gt;let vFileSize=FileSize('$(vFile)');&lt;BR /&gt;Let vFileExists=if(vFileSize&amp;gt;0,-1,0);&lt;BR /&gt;let vFileTime= Timestamp(FileTime('$(vFile)'),'YYYY-MM-DD hh:mm:ss');&lt;/P&gt;&lt;P&gt;if $(vFileExists) and ('$(vFileTime)' &amp;gt;= '$(vLastExecution)' and '$(vFileTime)' &amp;lt; '$(vThisExecution)') then&lt;/P&gt;&lt;P&gt;Concatenate(FilesHistTemp)&lt;BR /&gt;LOAD *,&lt;BR /&gt;$(vMonthEndNum) as MonthEndNum,&lt;BR /&gt;FileTime() as FileTimeStamp,&lt;BR /&gt;Port &amp;amp; Num(Floor(Date)) as PrimarKey&lt;BR /&gt;FROM [$(vFile)]&lt;BR /&gt;(txt, codepage is 1252, embedded labels, delimiter is ',', msq);&lt;/P&gt;&lt;P&gt;EndIf;&lt;/P&gt;&lt;P&gt;NEXT vFile;&lt;/P&gt;&lt;P&gt;if vMonth = 12 then&lt;BR /&gt;let vPeriod = (vYear+1)*100 + 1;&lt;BR /&gt;else&lt;BR /&gt;vPeriod = vPeriod + 1;&lt;BR /&gt;endif;&lt;BR /&gt;&lt;BR /&gt;loop;&lt;BR /&gt;&lt;BR /&gt;Concatenate(FilesHistTemp)&lt;BR /&gt;Load *&lt;BR /&gt;From [$(vHistoricalQVD)] (qvd)&lt;BR /&gt;Where not Exists(PrimaryKey,Port &amp;amp; Num(Floor(Date)));&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;drop fields x,PrimaryKey;&lt;/P&gt;&lt;P&gt;Store * from FilesHistTemp into [$(vHistoricalQVD)] (qvd);&lt;BR /&gt;Drop Table FilesHistTemp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;BR /&gt;Mark&lt;/P&gt;</description>
    <pubDate>Sat, 16 Nov 2024 06:36:38 GMT</pubDate>
    <dc:creator>m_perreault</dc:creator>
    <dc:date>2024-11-16T06:36:38Z</dc:date>
    <item>
      <title>Insert Update Incremental Load</title>
      <link>https://community.qlik.com/t5/App-Development/Insert-Update-Incremental-Load/m-p/1543286#M39182</link>
      <description>&lt;P&gt;Hi All,&lt;/P&gt;&lt;P&gt;I have file structure such as below.&amp;nbsp; Each Folder will have a number of different files.&amp;nbsp; Currently I have a load that loops through each file in the folder to make a QVD and I want to improve this process by making an Incremental Load.&amp;nbsp; Note it is possible for files in past Months folders to change.&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am utilizing an Insert Update, incremental methodology.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="FileStrcuture.png" style="width: 560px;"&gt;&lt;img src="https://community.qlik.com/t5/image/serverpage/image-id/5806i02F507959B44626F/image-size/large?v=v2&amp;amp;px=999" role="button" title="FileStrcuture.png" alt="FileStrcuture.png" /&gt;&lt;/span&gt;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I've implemented the below Incremental Script and it reduces the load from ~10 minutes to ~6 minutes but I am wondering if anyone has any suggestions on how I could optimize it to make it even faster?&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;FilesHistTemp:&lt;BR /&gt;Load * inline&lt;BR /&gt;[&lt;BR /&gt;x&lt;BR /&gt;];&lt;/P&gt;&lt;P&gt;let vPeriod = Num('$(vMinPeriod)');&lt;/P&gt;&lt;P&gt;let vLastExecution = TimeStamp(QvdCreateTime('$(vHistoricalQVD)'),'YYYY-MM-DD hh:mm:ss');&lt;BR /&gt;let vThisExecution = Timestamp(Now(),'YYYY-MM-DD hh:mm:ss');&lt;/P&gt;&lt;P&gt;do while vPeriod &amp;lt; Year(Today())*100+Month(Today())&lt;/P&gt;&lt;P&gt;let vYear = Num(left(Text(vPeriod),4));&lt;BR /&gt;let vMonth = Num(right(Text(vPeriod),2));&lt;BR /&gt;let vFolder = left(Text(vPeriod),4)&amp;amp;'-'&amp;amp;right(Text(vPeriod),2);&lt;BR /&gt;let vMonthEndNum = num(date#(monthend(date#('$(vPeriod)','YYYYMM'))));&lt;/P&gt;&lt;P&gt;FOR Each vFile in filelist('$(vHistoricalPath)\$(vFolder)\$(vHistoricalFile)')&lt;/P&gt;&lt;P&gt;let vFileSize=FileSize('$(vFile)');&lt;BR /&gt;Let vFileExists=if(vFileSize&amp;gt;0,-1,0);&lt;BR /&gt;let vFileTime= Timestamp(FileTime('$(vFile)'),'YYYY-MM-DD hh:mm:ss');&lt;/P&gt;&lt;P&gt;if $(vFileExists) and ('$(vFileTime)' &amp;gt;= '$(vLastExecution)' and '$(vFileTime)' &amp;lt; '$(vThisExecution)') then&lt;/P&gt;&lt;P&gt;Concatenate(FilesHistTemp)&lt;BR /&gt;LOAD *,&lt;BR /&gt;$(vMonthEndNum) as MonthEndNum,&lt;BR /&gt;FileTime() as FileTimeStamp,&lt;BR /&gt;Port &amp;amp; Num(Floor(Date)) as PrimarKey&lt;BR /&gt;FROM [$(vFile)]&lt;BR /&gt;(txt, codepage is 1252, embedded labels, delimiter is ',', msq);&lt;/P&gt;&lt;P&gt;EndIf;&lt;/P&gt;&lt;P&gt;NEXT vFile;&lt;/P&gt;&lt;P&gt;if vMonth = 12 then&lt;BR /&gt;let vPeriod = (vYear+1)*100 + 1;&lt;BR /&gt;else&lt;BR /&gt;vPeriod = vPeriod + 1;&lt;BR /&gt;endif;&lt;BR /&gt;&lt;BR /&gt;loop;&lt;BR /&gt;&lt;BR /&gt;Concatenate(FilesHistTemp)&lt;BR /&gt;Load *&lt;BR /&gt;From [$(vHistoricalQVD)] (qvd)&lt;BR /&gt;Where not Exists(PrimaryKey,Port &amp;amp; Num(Floor(Date)));&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;drop fields x,PrimaryKey;&lt;/P&gt;&lt;P&gt;Store * from FilesHistTemp into [$(vHistoricalQVD)] (qvd);&lt;BR /&gt;Drop Table FilesHistTemp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thanks,&lt;BR /&gt;Mark&lt;/P&gt;</description>
      <pubDate>Sat, 16 Nov 2024 06:36:38 GMT</pubDate>
      <guid>https://community.qlik.com/t5/App-Development/Insert-Update-Incremental-Load/m-p/1543286#M39182</guid>
      <dc:creator>m_perreault</dc:creator>
      <dc:date>2024-11-16T06:36:38Z</dc:date>
    </item>
  </channel>
</rss>

