sql server存儲過程語法

-- 变量的声明,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 @[email protected]+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         //移除資料指標參考

时间: 2024-10-24 13:43:50

sql server存儲過程語法的相关文章

SQL使用存儲過程訪問不同服務器

用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLEDB', 'sql服务器名'; '用户名'; '密码', 数据库名.dbo.表名) --导入示例 select * into 表 from openrowset('SQLOLEDB' ,'sql服务器名';'用户名';'密码' ,数据库名.dbo.表名) --创建链接服务器 exec sp_addlinkedserve

mySQL 創建存儲過程procedure

1.mySQL 創建存儲過程procedure 如下圖: /*奇葩之處竟然要定義個標記[delimiter //]表示是procedure 不是sql ,procedure 的關鍵字被狗吃了?*/ 2.流程控制語句 if then  end if 3.case when end case . 4.while end while /* end while 是亮點,這個和Oracle 不一樣*/ 5.loop end loop 循環: 6.repeat   until  end repeat; /*

數據庫ORACLE轉MYSQL存儲過程遇到的坑~(總結)

ORACLE數據庫轉MySQL數據庫遇到的坑 總結 最近在做Oracle轉mysql的工程,遇到的坑是真的多,尤其是存儲過程,以前都沒接觸過類似的知識,最近也差不多轉完了就總結一下.希望能幫到一些人(包括以後的自己)~ 1> 基本語法 變量聲明: oracle:   v_cnt varchar2(100) := ' ' ; mysql:   DECLARE v_cnt VARCHAR(100) DEFAULT  ' '; 存儲過程聲明: oracle:  procedure regNewReco

存儲過程

USE  DB名稱 GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER  ON GO CREATE  PROCEDURE 存儲過程名稱 @變量名稱      變量類型 AS DECLARE    @變量名稱      變量類型 BEGIN SET  NOCOUNT ON; 執行過程 END 原文地址:https://www.cnblogs.com/ximi07/p/10222104.html

簡單SQL存儲過程實例

实例1:仅仅返回单一记录集的存储过程. 银行存款表(bankMoney)的内容例如以下 Id userID Sex Money 001 Zhangsan 男 30 002 Wangwu 男 50 003 Zhangsan 男 40 要求1:查询表bankMoney的内容的存储过程 create procedure sp_query_bankMoneyasselect * from bankMoneygoexec sp_query_bankMoney 注*  在使用过程中仅仅须要把中的SQL语句替

Nhibernate/Hibernate 使用存儲過程 多參數設置

<?xml version="1.0" encoding="utf-8" ?> <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" namespace="Mrp.Domain" assembly="Mrp.Domain"> <class name="GetQpmrpWorkDomain"> <

[SQL Server] sysobjects的介紹

sysobjects表 數據庫中所創建的每個對象(約束.默認值.日誌.規則.存儲過程等)都各以一行資訊呈現於表中. 而臨時對象只有在tempdb內,才在該表中各佔一行. sysobjects 表結構: 列名 數據類型 描述 name sysname 對象名,常用列 id int 對象標識號 xtype char(2) 對像類型.常用列.xtype可以是下列對像類型中的一種:  C = CHECK約束D =默認值或DEFAULT約束F = FOREIGN KEY約束L =日誌FN =標量函數  I

為 Swift 代碼編寫含有 Mardown 語法的文檔

原文:Documenting Your Swift Code in Xcode Using Markdown 作者:GABRIEL THEODOROPOULOS 译者:kmyhy 在 Xcode 7 的所有新功能中,有一個最引人注目的新功能,能够讓你以更好的方式来书写代码文檔.從 Xcode 7 開始,開發者終於可以在他們的文檔中使用强大 Markdown 語法來進行富文本编辑了,Markdown 語法用一些特殊的關鍵字來描述文檔中的不同部分,比如參數.函數返回值等,從而使這些結構顯示出不同的樣

Delphi APP 開發入門(六)Object Pascal 語法初探

Delphi APP 開發入門(六)Object Pascal 語法初探 分享: Share on facebookShare on twitterShare on google_plusone_share 閲讀次數:3442 發表時間:2014/06/10 tags: 行動開發 教學 App Delphi XE6 Android iOS Delphi APP 開發入門(五)GPS 定位功能 << 前情 經過前面五週幾乎每週可以寫出一個簡單App後,大家都可以感受到Delphi強大的開發威力!