1

例如:

CREATE PROCEDURE [dbo].[procGetTable]
    (
      @SetUPDLOCK BIT,
      @RecordId BigInt
    ) 
AS

SELECT * 
FROM MYTABLE WITH (CASE WHEN @SetUPDLOCK = 1 THEN 'UPDLOCK' ELSE '' END)
WHERE MYTABLE.RecordId = @RecordId

/* PS 我知道上面的内容仅在概念上不起作用 */

4

1 回答 1

2
CREATE PROCEDURE [dbo].[procGetTable]
      @SetUPDLOCK BIT,
      @RecordId BigInt
AS
BEGIN
   SET NOCOUNT ON; 

    IF (@SetUPDLOCK = 1 )
      BEGIN
            SELECT * 
            FROM MYTABLE WITH (UPDLOCK)
            WHERE MYTABLE.RecordId = @RecordId
       END
    ELSE 
      BEGIN
            SELECT * 
            FROM MYTABLE
            WHERE MYTABLE.RecordId = @RecordId
       END
END
于 2015-08-09T23:34:40.317 回答