Recently, I had noticed that deleting a file in SSIS using the File System Task is not straightforward specially when your file is not hardcoded in your package but it is declared as a variable. I just noticed it when I was creating a Foreach Loop Container using a File enumerator.
data:image/s3,"s3://crabby-images/9328b/9328ba142441a8c398764fd0f578589e65cf2a5f" alt="image003"
Inside that for
loop is a Script Task which manipulates the file and a File System Task which now deletes when the whole process is done.
data:image/s3,"s3://crabby-images/fb595/fb595817d934ac6fb4f2642acccc69d9e3c3d9e0" alt="image002"
Initially I was using a variable to delete a file like this:
data:image/s3,"s3://crabby-images/cc9c9/cc9c982fc553bfe9150572ae7cad3cdfbcd18e17" alt="image001"
But trust me, you will encounter an error that will tell you that Variable “something” is used as a source or destination and is empty. I found another workaround by using expressions to come out with the filename but still it gives me some error to the likes of [File System Task] Error: An error occurred with the following error message: “The process cannot access the file ‘C:YourFile.txt’ because it is being used by another process.”
data:image/s3,"s3://crabby-images/4a804/4a804668943ba72b102799c9ec9bce6aa8cc4dde" alt="image004"
So after a bit of playing around, I found a solution - the workaround is a bit of pain but it works. First, you have to create a Dummy Flat File Connection String by adding it to your connection manager. Give it a Name and point it to any text file with some content (so the OK button will enable and save it).
data:image/s3,"s3://crabby-images/31e3c/31e3c053ce2ebf268e78cd87101367b68da9f7fd" alt="image005"
Now edit the properties of the Flat File Connection Manager, remove the Connection String and add a new expression using the connection string pointing to your File Variable which was outputted from the ForEach Loop Container.
data:image/s3,"s3://crabby-images/0ab2d/0ab2d1792793637eef8447a7508dd212722650b2" alt="image006"
Here is how you output the variable in the For Each Loop.
data:image/s3,"s3://crabby-images/310fa/310fa6dd1234e8d7d438f46463e98b6d6eddda50" alt="image007"
Now use that connection string in your File System Task, by making the Source Path Variable to false
and Source Connection to the connection string you had just created.
data:image/s3,"s3://crabby-images/0d04f/0d04fcb3e7941d70dc19e58633d7d51651f1be50" alt="image008"
The solution bypassed the Path
Variable being True
but the Connection String becomes now the dynamic variable.