April 20, 2017 at 8:16 am
I have mapped 2 parameters - named 0 , 1 within the task
Then I have tried EXEC spName ? , ?
I have tried it with EXEC spName @paramname = ? , @paramname2 = ?
I have tried it with teh mapped parameters named matching the TSQL param names.
Still getting errors.
I have read all the MS stuff - still cant find what I should be doing. Any help mist apprecitated?
April 20, 2017 at 8:31 am
First - What errors are you getting? We can't help without knowing those.
Second - Are you connecting to the correct database?
Third - Does the stored procedure run outside of SSIS?
Fourth - Are you running this under an account with the correct permissions?
Almost everything starts with answers to that first question - what errors are you getting?
April 20, 2017 at 8:37 am
Thanks
1)[Execute SQL Task] Error: Executing the query "EXEC ProcTPSUpdate @intJob = ? , @varCharUserName ..." failed with the following error: "The statement has been terminated.". Possible failure reasons: Problems with the query, "ResultSet" property not set correctly, parameters not set correctly, or connection not established correctly.
2)Yes
3)yes
4)Its runs ok if ihard code teh parameter values in SSIS rather than using teh mapped parameters.
So I think its something to do with my names/mappings.
April 20, 2017 at 8:38 am
Or
[Execute SQL Task] Error: Executing the query "EXEC ProcTPSUpdate ? , ?" failed with the following error: "The statement has been terminated.". Possible failure reasons: Problems with the query, "ResultSet" property not set correctly, parameters not set correctly, or connection not established correctly.
April 20, 2017 at 9:58 am
Please post a screen shot of the screen where you have configured the parameter mappings.
The absence of evidence is not evidence of absence.
Martin Rees
You can lead a horse to water, but a pencil must be lead.
Stan Laurel
April 20, 2017 at 10:14 am
Thanks Phil - it could be to do with datatype or size even?
April 21, 2017 at 3:39 am
I can get this to work with an ODBC connection. Is it possible to use an ODBC connection DSN less. I cant get my data to load to my table using ODBC howver! Swings and roundabouts!
Then theres OLE depreciation to think of? Any advice greatly received.
https://social.msdn.microsoft.com/Forums/sqlserver/en-US/92390f70-e17d-4f9f-9965-97746f3f7dc8/ssis-ole-db-deprecation-what-to-do-about-it?forum=sqlintegrationservices
April 21, 2017 at 4:01 am
Have you tried specifying a parameter size for Parameter 1? Also, what system variable are you passing to that parameter?
John
April 21, 2017 at 4:29 am
John Mitchell-245523 - Friday, April 21, 2017 4:01 AMHave you tried specifying a parameter size for Parameter 1? Also, what system variable are you passing to that parameter?John
Thanks John - I seem to have got round it by building teh SQL Source as an expression so
"EXEC ProcTPSUPDATE " + (DT_WSTR, 10) @[User::JobID] + ",'" + RIGHT( @[System::CreatorName] , LEN( @[System::CreatorName] ) - FINDSTRING( @[System::CreatorName] , "\\", 1 ) ) + "'"
hopefully it now works. I'd still like to know how to map the parameters. the fisrt param is bigint in SQL and int64 as variable in SSIS and I was trying long as datatype in the parameter mapping? Thanks
April 21, 2017 at 4:37 am
I'm pleased that works for you - but you're right, it's much better to know how to use it properly. It's less typing, for a start! I think the issue might be the sizing of the second parameter (which is what I meant by Parameter 1). When you have a string data type, you need to specify a length.
John
April 21, 2017 at 5:06 am
John Mitchell-245523 - Friday, April 21, 2017 4:37 AMI'm pleased that works for you - but you're right, it's much better to know how to use it properly. It's less typing, for a start! I think the issue might be the sizing of the second parameter (which is what I meant by Parameter 1). When you have a string data type, you need to specify a length.John
Right - I seem to have solved what caused the error.
In the proc second paramater was varChar(30) - but was insering data to a field varChar(25) - worked fine when called in via sql. Works find when called like EXEC procTPSUpdate 12 , "Adam" from SSIS execute SQL Task.
Errors if called as EXEC procTPSUpdate ? , "Adam"
So even if the length of the string actually attempted to be passed was OK it errors.
Works OK if I change the TSQL in the proc to have varChar(25) - even when I use parmeter mapping with both parameters length -1?
Thats what seems to be happnening anyway?
If you can shed any light onto what may be happening - all teh better. Otherwise thanks for your help.
Thanks everyone..
April 24, 2017 at 8:02 am
I noticed that you were getting Result Set errors. That leads me to believe that you've set the task to have a result set but haven't directed it to a variable. Can you post a screen print of the task to show that option? Or confirm what you have that set to and/or that you have a Result Set variable as needed?
April 24, 2017 at 8:21 am
JustMarie - Monday, April 24, 2017 8:02 AMI noticed that you were getting Result Set errors. That leads me to believe that you've set the task to have a result set but haven't directed it to a variable. Can you post a screen print of the task to show that option? Or confirm what you have that set to and/or that you have a Result Set variable as needed?
Thanks Marie - i had results set to none. Solution seemed to be above - sp variable was length 30 but inserting data to length 25. All worked fine in SQL Itself, or indeed does not when called with data from SSIS exceeding 25 (its automatically is truncating it) . And with hard coded arguments from SSIS even with the size mismatch.
Just one of those things to look out for I suppose. Thanks for your help.
Viewing 13 posts - 1 through 12 (of 12 total)
You must be logged in to reply to this topic. Login to reply