2015-04-24 44 views
0
的存儲過程變量

我想將變量'@Xdate'設置爲'dbo.Mtabel'中的'updated'字段。來自表

ALTER PROCEDURE [dbo].[SP_Mproc] 
(
@snumber nvarchar(50), 
@inumber nvarchar(10), 
@tdate datetime 
) 
AS 
IF exists (Select snumber, updated FROM dbo.Mtabel Where snumber = @snumber AND inumber = @inumber) 
GO 
declare 
    @Xdate datetime, 
    @sdate datetime 

select 
    @Xdate = [email protected], 
    @Ydate = GETDATE() 
+1

標籤使用的數據庫管理系統,讓你得到正確的關注! (非ANSI SQL在這裏涉及......) – jarlh

+2

注意,如果是** SQL Server **:你應該**不要**爲存儲過程使用'sp_'前綴。微軟[留作自己使用前綴(見*命名存儲過程*)(http://msdn.microsoft.com/en-us/library/ms190669%28v=sql.105%29.aspx),和你將來有可能冒着名字衝突的風險。 [這對你的存儲過程性能也是不利的](http://www.sqlperformance.com/2012/10/t-sql-queries/sp_prefix)。最好只是簡單地避免使用'sp_'並將其他內容用作前綴 - 或者根本沒有前綴! –

回答

0
SELECT @xdate = updated, @ydate=getdate() FROM dbo.Mtabel WHERE snumber = @snumber AND inumber = @inumber 
0
ALTER PROCEDURE [dbo].[SP_Mproc] 
(
    @snumber nvarchar(50), 
    @inumber nvarchar(10), 
    @tdate datetime 
) 
AS 

declare @Xdate datetime, @Ydate datetime 
Select @Xdate = updated, @Ydate = getDate() FROM dbo.Mtabel Where snumber = @snumber AND inumber = @inumber 
IF @@ROWCOUNT > 0 
BEGIN 
    -- @Xdate contains 'updated', @Ydate contains current datetime 
    ... 
END 
GO 

這是爲了防止你在做相同數據的多個呼叫。

0

試試這個

CREATE TABLE #YourTable 
    (id varchar(50),Date1 Date, Date2 Date) 
; 

INSERT INTO #YourTable 
    (id, Date1, Date2) 
VALUES 
    ('1','2015-01-10','2015-01-20'), 
    ('2','2015-01-20','2015-01-11'), 
    ('3','2015-01-15','2014-01-15'), 
    ('4','2015-02-18','2016-03-09') 
; 
-- select * from #YourTable 


Declare @Xdate date 
select @Xdate= Date2 from #YourTable where Date2 > GETDATE() 
print @Xdate