Go Premium for a chance to win a PS4. Enter to Win

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 384
  • Last Modified:

Set Trigger Order

A co-worker was telling me there is a stored procedure called sp_SetTriggerOrder supposedly in the master database. He is trying to figure out the parameters that are passed into it. However he can not find it in the master database. Does anybody know where this is located?

Lmred
0
lmred
Asked:
lmred
  • 5
  • 3
  • 3
1 Solution
 
Anthony PerkinsCommented:
From MSDN:
<quote>
sp_settriggerorder
Specifies which AFTER triggers associated with a table will be fired first or last. The AFTER triggers that will be fired between the first and last triggers will be executed in undefined order.

Syntax
sp_settriggerorder[@triggername = ] 'triggername'
    , [@order = ] 'value'
    , [@stmttype = ] 'statement_type'

Argument
[@triggername = ] 'triggername'

Is the name of the trigger whose order will be set or changed. triggername is sysname. If the name does not correspond to a trigger or if the name corresponds to an INSTEAD OF trigger, the procedure will return an error.

[@order = ] 'value'

Is the setting for the new trigger order. value is varchar(10) and it can be any of the following values.



Important  The First and Last triggers must be two different triggers.


Value Description
First Trigger will be fired first.
Last Trigger will be fired last.
None Trigger will be fired in undefined order.


[@stmttype = ] 'statement_type'

Specifies which SQL statement fires the trigger. statement_type is varchar(10) and can be INSERT, UPDATE, or DELETE. A trigger can be designated as the First or Last trigger for a statement type only after that trigger has been defined as a trigger for that statement type. For example, trigger TR1 can be designated First for INSERT on table T1 if TR1 is defined as an INSERT trigger. SQL Server will return an error if TR1, which has been defined only as an INSERT trigger, is set as a First (or Last) trigger for an UPDATE statement. For more information, see the Remarks section.

Return Code Values
0 (success) and 1 (failure)

Remarks
There can be only one First and one Last trigger for each of INSERT, UPDATE, or DELETE statement on a single table.

If a First trigger is already defined on the table, you cannot designate a new trigger as First for the same table for the same operation (INSERT, UPDATE, or DELETE). This restriction also applies Last triggers.

As part of SQL Server replication, a First trigger can be designated on a published table; however, if a conflict with the user-defined trigger exists, the designation of the user-defined trigger must be changed to None before the table can be published.

If an ALTER TRIGGER statement changes a first or last trigger, the First or Last attribute originally set on the trigger is dropped, and the value is replaced by None. The order value must be reset with sp_settriggerorder.

If the same trigger has to be designated as the first or last order for more than one statement type, sp_settriggerorder must be executed for each statement type. Also, the trigger must be first defined for a statement type before it can be designated as the First or Last trigger to fire for the statement type.

Permissions
The owner of the trigger and the table on which the trigger is defined has execute permissions for sp_settriggerorder. Members of db_owner and db_ddladmin roles in the current database, as well as the sysadmin server role can execute this stored procedure.

Examples
sp_settriggerorder @triggername= 'MyTrigger', @order='first', @stmttype = 'UPDATE'

</quote>
0
 
lmredAuthor Commented:
When this syntax is placed in SQL Server Analyzer (we are using 2000), it does not run. It says it can not find this stored procedure. Even when you put master..spSetTriggerOrder it does not run.
0
 
Anthony PerkinsCommented:
This sounds like a permissions problem.

Anthony
0
Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

 
Scott PletcherSenior DBACommented:
Be sure to code sp_SetTriggerOrder rather than spSetTriggerOrder.
0
 
lmredAuthor Commented:
The underscore has been placed in the name of the stored procedure.
0
 
Scott PletcherSenior DBACommented:
I think acperkins is right, it does sound like a permissions problem.  

You can use EM to verify that the SP exists in master, then right click on it, select Properties, click on Permissions..., and verify that Public has EXEC authority (that appears to be the default).
0
 
lmredAuthor Commented:
It does not show up in master.
0
 
Scott PletcherSenior DBACommented:
Are you looking at a 7.0 server?  As you know, that SP does not exist on 7.0.  But that SP should be there, in the master db, on a 2000 server.  If it's not, I would suggest you back up the databases and re-install SQL 2K.
0
 
Anthony PerkinsCommented:
Are you using SQL Server 7?

I believe the sp_SetTriggerOrder was introduced with SQL Server 2000.

Anthony
0
 
lmredAuthor Commented:
Yes, I am looking at SQL 7. That does explain it. Thanks.


Lisa
0
 
lmredAuthor Commented:
Thanks everybody for your help!

Lisa
0

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 5
  • 3
  • 3
Tackle projects and never again get stuck behind a technical roadblock.
Join Now