下面的SQL語句該怎麼寫啊?

來源:互聯網
上載者:User
IF  EXISTS (SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[dbo].[TheWay_Membership_CreateUser]') AND OBJECTPROPERTY(id,N'IsProcedure') = 1)
DROP PROCEDURE [dbo].[TheWay_Membership_CreateUser]
GO

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER OFF
GO

CREATE PROCEDURE [dbo].[TheWay_Membership_CreateUser]
    @UserName                               nvarchar(256),
    @Password                               nvarchar(128),
    @Salt                           nvarchar(128),
    @Email                                  nvarchar(256),
    @PasswordQuestion                       nvarchar(256),
    @PasswordAnswer                         nvarchar(128),
    @IsApproved                             bit,
    @UniqueEmail                            int      = 0,
    @PasswordFormat                         int      = 0,
    @NewUserID  int OUTPUT 
AS
    PRINT 'ERROR: No title_id was specified.'
    SELECT @NewUserID=0    
   --檢查是否已經有相同的使用者名稱存在,存在則返回-1
   IF ( EXISTS ( SELECT UserID FROM   dbo.TheWay_Users WHERE  UserName = @UserName ) )
         BEGIN
            RETURN(-1)
         END
   ELSE
        IF(@UniqueEmail = 1)
            BEGIN--檢查是否要求要不重複的Email,如果要求,則檢查是否已經存在相同的Email,如果存在返回-2
                IF(EXISTS(SELECT UserID FROM dbo.TheWay_Users WHERE Email = @Email))
                    BEGIN
                        RETURN(-2)
                    END
            END
  ELSE
    BEGIN
        --插入必要的資料到資料庫,並將UserID查詢返回,成功則返回1
        INSERT INTO dbo.TheWay_Users
        (
        UserName,
        Password,
        PasswordFormat,
        Salt,
        PasswordQuestion,
        PasswordAnswer,
        Email,
        IsApproved
        )
        VALUES
        (
        @UserName,
        @Password,
        @PasswordFormat,
        @Salt,
        @PasswordQuestion,
        @PasswordAnswer,
        @Email,
        @IsApproved        
        )
        IF(EXISTS(SELECT @NewUserID=UserID FROM dbo.TheWay_Users Where UserName=@UserName))
            BEGIN
                RETURN(1)
            END
        ELSE
            BEGIN
                RETURN(-3)
            END
        END
GO

我是個菜鳥,幫幫忙。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.