我正在尝试执行一个for循环,该循环以类似'201812'的格式传递开始日期,并递增递增至'201903'的结束日期(例如)。变量作为整数传递给存储的proc,然后该proc根据这些值获取并插入数据。我正在尝试实现此处找到的模式,但它似乎没有正确递增:
SSIS For Loop Container with Date Variable
我将变量设置如下:
在此处的“执行SQL任务”中设置了ETLBeginPeriod和ETLEndPeriod:
然后是For循环中的表达式
AssignExpression中的完整表达式为
@[User::Counter] = LEFT((DT_WSTR,19)(DATEADD("mm",1,(DT_DbdaTE)(LEFT((DT_WSTR,10) (@[User::Counter]),4) + "-" + RIGHT((DT_WSTR,2) + "-" + "01"))),4) + SUBSTRING((DT_WSTR,6,2)
在测试 AssignExpression 时,表达式本身确实返回正确的值(即它将201808
更改为201809
,但这似乎没有受到影响。将在初次通过时获得正确的值,然后运行201808
,然后使用201808
再试一次。因此,它似乎并没有改变计数值。