Policy-Based Management is one of the several nice features of SQL Server 2008. To explain how this feature is implemented, let me give you a real time scenario that I faced myself. The Manager I report to has been trying to implement naming standards across our firm. Two of his favorite naming standards are:
- The names of all user stored procedure should begin with usp.
- The names of all user created views should begin with Vwv.
Connect to your SQL server 2008 instance, expand the Management folder, then expand the Policy Management folder, right-click the Policies folder and select New Policy as shown in the figure below.
data:image/s3,"s3://crabby-images/0d31d/0d31d21b229eb95ce7cb2944b06164012f50293e" alt="Policy-Based Management 1"
The Create New Policy dialog box appears. Give an appropriate name for the policy and in the Check condition drop-down, select New Condition as shown in the figure below.
data:image/s3,"s3://crabby-images/72d5e/72d5ee6883140072107d8c739fb0efcdc886435a" alt="Policy-Based Management 2"
You can also select an existing condition that you have previously defined. (You can create a new condition by right-clicking the Conditions folder under Policy Management). Also, please note that you can only have one condition for a policy.
The Create New Condition dialog box appears as shown below. Type in an appropriate name for the condition, select Stored Procedure in the Facet drop-down and set the condition in the expression section as show in the figure below and click OK to return to the Create New Policy dialog box.
data:image/s3,"s3://crabby-images/817bb/817bbb4e90a9a296061dc0a69abdc36054e52cac" alt="Policy-Based Management 3"
Your screen should look similar to the one shown in the figure below.
data:image/s3,"s3://crabby-images/bbe43/bbe430bbf1cf89390e7a294bcdfdade8db260d76" alt="Policy-Based Management 6"
In the Against targets, you can either apply the condition to all the stored procedures or create a condition(by clicking the down arrow next to StoredProcedure) to apply it to only the required ones. The same applies to Database; you can apply the condition to stored procedures in all the database or create a condition to apply that to only the required ones.
In the Evaluation Mode drop-drown, you have 3 options to select:
- on demand - Use this option to evaluate the policy as and when required by the user. To evaluate a policy, right-click the Policy folder and select Evaluate.
- on schedule - Use this option to evaluate the policy automatically by creating a schedule using SQL Server Agent.
- on change: log only - This option uses event notification to evaluate a policy whenever the policy is violated.
- on change: prevent - This option automatically prevents the user from violating the policy. It uses DDL triggers behind the scenes.
Now lets try to create a stored procedure whose name doesn't begin with usp and see what happens.
data:image/s3,"s3://crabby-images/a9650/a96505343b04f2d0dc44ad55395c304821ec1ca5" alt="Policy-Based Management 7"
As shown in the figure above, SQL Server prevented the creation of stored procedure since its violating the policy we just created.
No comments:
Post a Comment