-- 變數的聲明,sql裡面聲明變數時必須在變數前加@符號
DECLARE @I INT
-- 變數的賦值,變數賦值時變數前必須加set
SET @I = 30
-- 聲明多個變數
DECLARE @s varchar(10),@a INT
-- Sql 裡if語句
IF 條件 BEGIN
執行語句
END
ELSE BEGIN
執行語句
END
DECLARE @d INT
set @d = 1
IF @d = 1 BEGIN
-- 列印
PRINT '正確'
END
ELSE BEGIN
PRINT '錯誤'
END
-- Sql 裡的多條件選擇語句.
DECLARE @iRet INT, @PKDisp VARCHAR(20)
SET @iRet = 1
Select @iRet =
CASE
WHEN @PKDisp = '一' THEN 1
WHEN @PKDisp = '二' THEN 2
WHEN @PKDisp = '三' THEN 3
WHEN @PKDisp = '四' THEN 4
WHEN @PKDisp = '五' THEN 5
ELSE 100
END
-- 迴圈語句
WHILE 條件 BEGIN
執行語句
END
DECLARE @i INT
SET @i = 1
WHILE @i<1000000 BEGIN
set @i=@i+1
END
-- 列印
PRINT @i
-- Select INTO 從一個查詢的計算結果中建立一個新表。 資料並不返回給用戶端,這一點和普通的
-- Select 不同。 新表的欄位具有和 Select 的輸出欄位相關聯(相同)的名字和資料類型。
select * into NewTable
from Uname
-- Insert INTO Select
-- 表ABC必須存在
-- 把表Uname裡面的欄位Username複製到表ABC
Insert INTO ABC Select Username FROM Uname
-- 建立暫存資料表
Create TABLE #temp(
UID int identity(1, 1) PRIMARY KEY,
UserName varchar(16),
Pwd varchar(50),
Age smallint,
Sex varchar(6)
)
-- 開啟暫存資料表
Select * from #temp
-- 預存程序
-- 要建立預存程序的資料庫
Use Test
-- 判斷要建立的預存程序名是否存在
if Exists(Select name From sysobjects Where name='csp_AddInfo' And
type='P')
-- 刪除預存程序
Drop Procedure dbo.csp_AddInfo
Go
-- 建立預存程序
Create Proc dbo.csp_AddInfo
-- 預存程序參數
@UserName varchar(16),
@Pwd varchar(50),
@Age smallint,
@Sex varchar(6)
AS
-- 預存程序語句體
insert into Uname (UserName,Pwd,Age,Sex)
values (@UserName,@Pwd,@Age,@Sex)
RETURN
-- 執行
GO
-- 執行預存程序
EXEC csp_AddInfo 'Junn.A','123456',20,'男'
有關遊標的問題
declare db cursor for //聲明一個遊標(db為其名稱)
SELECT UNIT_NAME FROM UNIT WHERE LEFT(UNIT_CODE,2)=LEFT(@strTO,2)//記錄集
open db //打開遊標
fetch next from db into @strUNIT_NAME //將第一個值放入一個參數中
while @@fetch_status = 0 ---存在本筆值向下循環
(0:順利執行;-1:失敗,或資料列超出結果集;-2:擷取的資料列已遺漏)
BEGIN ----開始循環
//個體操作
End ----結束循環
Close db ---關閉遊標
deallocate db //移除資料指標參考