Why is "Use environment variable" option disabled/grayed out in SSIS2012 catalog configuration?
Asked Answered
R

3

14

This may sound like an easy question but the answers on the net all point to the basics of setting up an environment and referencing it in the project/package.

The scenario that I have encountered was never mentioned anywhere so I thought it would be good to document the behaviour here.

Below is the steps to reproduce the problem:
1. Create a new package: Package1.dtsx
2. Create a new (package) parameter: Test, Int32, Required
3. Deploy the project.
4. Goto Integration Services Catalogs and navigate to the package.
5. Right click on the package and then Configure...
6. Click on "..." next to the package parameter Test
7. You will see that "Use environment variable" option is disabled/grayed out.

Set Parameter Value

Why is that?

Rhyner answered 1/4, 2014 at 2:56 Comment(0)
R
13

Most answers from blogs and forums will now say that you need to create an environment and link it to the package, blah, blah. However, none of them mentions the fact that in order for the option to be enabled, you must have variables with MATCHING DATA TYPES!

Allow me to demonstrate.

  1. Create an environment: Demo
  2. Create a variable: Test, String
  3. Notice that the data type of the environment variable is different to the package paramter.
  4. Link the environment Demo to the package Package1.dtsx
  5. This is where most answers on the net stop. If you have done what I've told you to do up until now, your "Use environment variable option is still disabled/grayed out. Why? Because the data types are not matching. IMPORTANT - variable names don't have to match, only the data types.
  6. Now let's finish it. Go back to the environment and create another variable that's Int32: Aha, Int32, 0
    Environment Variables
  7. Go back to Configure... and click on "..." next to the package parameter Test
  8. See how the "Use environment variable" option is now enabled? Use environment variable option is enabled
Rhyner answered 1/4, 2014 at 2:56 Comment(0)
J
26

Before you can map them together, you have to click References and Add the Environment that you created for that package, then it will be enabled for you.

Jangro answered 27/1, 2015 at 15:6 Comment(2)
Ben, this answer does add to the question: if an environment is not associated with a project/package, the option "Use environment variable" will be greyed out, even if the variables do have matching datatypes.Ketosis
this was what stumped me. it took me a while to figure out what does it mean to 'link' your package with the environment. This is a step in between step 5 and 6 in the original post.Delainedelainey
R
13

Most answers from blogs and forums will now say that you need to create an environment and link it to the package, blah, blah. However, none of them mentions the fact that in order for the option to be enabled, you must have variables with MATCHING DATA TYPES!

Allow me to demonstrate.

  1. Create an environment: Demo
  2. Create a variable: Test, String
  3. Notice that the data type of the environment variable is different to the package paramter.
  4. Link the environment Demo to the package Package1.dtsx
  5. This is where most answers on the net stop. If you have done what I've told you to do up until now, your "Use environment variable option is still disabled/grayed out. Why? Because the data types are not matching. IMPORTANT - variable names don't have to match, only the data types.
  6. Now let's finish it. Go back to the environment and create another variable that's Int32: Aha, Int32, 0
    Environment Variables
  7. Go back to Configure... and click on "..." next to the package parameter Test
  8. See how the "Use environment variable" option is now enabled? Use environment variable option is enabled
Rhyner answered 1/4, 2014 at 2:56 Comment(0)
B
2

We have to first add environment variable in refernce inside package.

Blur answered 12/3, 2021 at 21:21 Comment(1)
Thanks. Your solution only worked for me.Crissie

© 2022 - 2025 — McMap. All rights reserved.