博客
关于我
SQL SERVER(36)存储过程
阅读量:206 次
发布时间:2019-02-28

本文共 2637 字,大约阅读时间需要 8 分钟。

CREATE PROCEDURE (Transact-SQL)

?Transact-SQL?????????????????????T-SQL?????????????????????????????

?????????

CREATE [OR ALTER] {PROC | PROCEDURE}     [schema_name.] procedure_name [ ; number ]     [ { @parameter [type_schema_name. ] data_type }         [VARYING] [ = default ] [OUT | OUTPUT | [READONLY]]         ] [ ,...n ] [ WITH             
[ ,...n ] ][ FOR REPLICATION ] AS { [ BEGIN ] sql_statement [;] [ ...n ] [ END ] }[;]
::= [ ENCRYPTION ] [ RECOMPILE ] [ EXECUTE AS Clause ]

????

  • schema_name?????????????
  • procedure_name?????????
  • ; number?????????????DROP PROCEDURE????????????
  • @parameter???????????
  • [type_schema_name. ]data_type??????????
  • VARYING?????CURSOR?????
  • default??????????
  • OUTPUT????????
  • ENCRYPTION????????
  • RECOMPILE????????????
  • EXECUTE AS Clause??????????????
  • FOR REPLICATION???????????????????
  • ??????????????

    CREATE PROC ProGetAuthorsASSELECT * FROM authorsGOEXEC ProGetAuthors

    ??????

    ??EXECUTE??

    EXEC [execute_permission]     [@return_status =] (procedure_name [; number] @procedure_name_var, ..., [WITH RECOMPILE])    [@parameter =] {value | @variable [OUTPUT] | [DEFAULT]}    ,...

    ????

  • @return_status??????????????????
  • @procedure_name_var???????????
  • ????????????

    CREATE PROC procGetAvgMaxMin     @course_name char (20)ASSELECT AVG(exam) AS ???,        MAX(exam) AS ???,        MIN(exam) AS ???FROM score AS sINNER JOIN course AS c ON s.cno = c.cnoWHERE c.cname = @course_nameGOEXEC procGetAvgMaxMin '????'

    ?????

    CREATE PROC procGetAvgMaxMin     @course_name char (20) = NULLASIF @course_name IS NULL    PRINT '???????'ELSE    SELECT AVG(exam) AS ???,            MAX(exam) AS ???,            MIN(exam) AS ???    FROM score AS s    INNER JOIN course AS c ON s.cno = c.cno    WHERE c.cname = @course_nameGOEXEC procGetAvgMaxMin '????'

    ??????????

    CREATE PROC proc2     @x int,     @Y int OUTPUTASDECLARE @i int, @t intSELECT @i = l, @t = lwhile @i < @x    begin        select @t = @t * @i        select @i = @i + 1    endselect @Y = @tGOEXEC proc2 5

    ????SQL???????

    CREATE PROC proc3     @course_name char (20)ASDECLARE @avg_score intSELECT AVG(exam) AS ???, MAX(exam) AS ???, MIN(exam) AS ???    FROM score AS s    INNER JOIN course AS c ON s.cno = c.cno    WHERE c.cname = @course_nameSELECT @avg_score = AVG(exam)    FROM score AS s    INNER JOIN course AS c ON s.cno = c.cno    WHERE c.cname = @course_nameSELECT sno, sname, depart, exam, usually    FROM stu_info AS st    INNER JOIN score AS s ON st.sno = s.sno    INNER JOIN course AS c ON s.cno = c.cno    WHERE c.cname = @course_name    AND s.exam > @avg_scoreGOEXEC proc3 '????'

    转载地址:http://cxgn.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现杰卡德距离算法(附完整源码)
    查看>>
    Objective-C实现极值距离算法(附完整源码)
    查看>>
    Objective-C实现构造n以内的素数表(附完整源码)
    查看>>
    Objective-C实现某文件夹下文件重命名(附完整源码)
    查看>>
    Objective-C实现查找整数数组中给定的最小数字算法(附完整源码)
    查看>>
    Objective-C实现根据cpu和磁盘序列号生成注册码( 附完整源码)
    查看>>
    Objective-C实现格雷码序列算法(附完整源码)
    查看>>
    Objective-C实现桥接模式(附完整源码)
    查看>>
    Objective-C实现检查给定图中是否存在循环算法(附完整源码)
    查看>>
    Objective-C实现检查给定字符串是否在camelCase中算法(附完整源码)
    查看>>
    Objective-C实现欧几里得距离(附完整源码)
    查看>>
    Objective-C实现求a的逆元x(附完整源码)
    查看>>
    Objective-C实现求众数(附完整源码)
    查看>>
    Objective-C实现求曲线在某点的导数(附完整源码)
    查看>>
    Objective-C实现求最大公约数 (GCD)的算法(附完整源码)
    查看>>
    Objective-C实现深度优先搜索递归算法(附完整源码)
    查看>>
    Objective-C实现牛顿下山法(附完整源码)
    查看>>
    Objective-C实现牛顿插值法(附完整源码)
    查看>>
    Objective-C实现牛顿法算法(附完整源码)
    查看>>
    Objective-C实现状态模式(附完整源码)
    查看>>