114 lines
2.8 KiB
Transact-SQL
114 lines
2.8 KiB
Transact-SQL
|
|
/****** Object: StoredProcedure [updateContent] ******/
|
|
IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[updateContent]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1)
|
|
DROP PROCEDURE [updateContent];
|
|
GO
|
|
|
|
CREATE PROCEDURE [dbo].[updateContent]
|
|
|
|
(
|
|
@ContentID int,
|
|
@Number nvarchar(256)=null,
|
|
@Text nvarchar(MAX)=null,
|
|
@Type int=null,
|
|
@FormatID int=null,
|
|
@Config nvarchar(MAX)=null,
|
|
@DTS datetime,
|
|
@UserID nvarchar(100),
|
|
@LastChanged timestamp,
|
|
@newLastChanged timestamp output
|
|
)
|
|
AS
|
|
BEGIN TRY -- Try Block
|
|
BEGIN TRANSACTION
|
|
UPDATE [Contents]
|
|
SET
|
|
[Number]=@Number,
|
|
[Text]=@Text,
|
|
[Type]=@Type,
|
|
[FormatID]=@FormatID,
|
|
[Config]=@Config,
|
|
[DTS]=@DTS,
|
|
[UserID]=@UserID
|
|
WHERE [ContentID]=@ContentID AND [LastChanged]=@LastChanged
|
|
IF @@ROWCOUNT = 0
|
|
BEGIN
|
|
IF NOT exists(select * from [Contents] WHERE [ContentID]=@ContentID)
|
|
RAISERROR('Content record has been deleted by another user', 16, 1)
|
|
ELSE
|
|
RAISERROR('Content has been edited by another user', 16, 1)
|
|
END
|
|
|
|
SELECT @newLastChanged=[LastChanged]
|
|
FROM [Contents] WHERE [ContentID]=@ContentID
|
|
|
|
IF( @@TRANCOUNT > 0 ) COMMIT
|
|
END TRY
|
|
BEGIN CATCH -- Catch Block
|
|
IF( @@TRANCOUNT = 1 ) ROLLBACK -- Only rollback if top level
|
|
ELSE IF( @@TRANCOUNT > 1 ) COMMIT -- Otherwise commit. Top level will rollback
|
|
EXEC vlnErrorHandler
|
|
END CATCH
|
|
GO
|
|
-- Display the status of Proc creation
|
|
IF (@@Error = 0) PRINT 'Procedure Creation: updateContent Succeeded'
|
|
ELSE PRINT 'Procedure Creation: updateContent Error on Creation'
|
|
GO
|
|
|
|
/****** Object: StoredProcedure [addContent] ******/
|
|
IF EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[addContent]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1)
|
|
DROP PROCEDURE [addContent];
|
|
GO
|
|
|
|
CREATE PROCEDURE [dbo].[addContent]
|
|
|
|
(
|
|
@Number nvarchar(256)=null,
|
|
@Text nvarchar(MAX)=null,
|
|
@Type int=null,
|
|
@FormatID int=null,
|
|
@Config nvarchar(MAX)=null,
|
|
@DTS datetime,
|
|
@UserID nvarchar(100),
|
|
@newContentID int output,
|
|
@newLastChanged timestamp output
|
|
)
|
|
AS
|
|
BEGIN TRY -- Try Block
|
|
BEGIN TRANSACTION
|
|
INSERT INTO [Contents]
|
|
(
|
|
[Number],
|
|
[Text],
|
|
[Type],
|
|
[FormatID],
|
|
[Config],
|
|
[DTS],
|
|
[UserID]
|
|
)
|
|
VALUES
|
|
(
|
|
@Number,
|
|
@Text,
|
|
@Type,
|
|
@FormatID,
|
|
@Config,
|
|
@DTS,
|
|
@UserID
|
|
)
|
|
SELECT @newContentID= SCOPE_IDENTITY()
|
|
SELECT @newLastChanged=[LastChanged]
|
|
FROM [Contents] WHERE [ContentID]=@newContentID
|
|
IF( @@TRANCOUNT > 0 ) COMMIT
|
|
END TRY
|
|
BEGIN CATCH -- Catch Block
|
|
IF( @@TRANCOUNT = 1 ) ROLLBACK -- Only rollback if top level
|
|
ELSE IF( @@TRANCOUNT > 1 ) COMMIT -- Otherwise commit. Top level will rollback
|
|
EXEC vlnErrorHandler
|
|
END CATCH
|
|
GO
|
|
-- Display the status of Proc creation
|
|
IF (@@Error = 0) PRINT 'Procedure Creation: addContent Succeeded'
|
|
ELSE PRINT 'Procedure Creation: addContent Error on Creation'
|
|
GO
|