zoukankan      html  css  js  c++  java
  • 创建存储过程

    UserAccount

    UserID

    UserName

    PassWord

    RegisterTime

    RegisterIP

    12

    6                   

    6                   

    2012-12-31

    6

    18

    5                   

    5                   

    2013-01-01

    5

    19

    1                   

    1                   

    2013-01-01

    1

    20

    2                   

    2                   

    2013-01-01

    2

    21

    3                   

    3                   

    2013-01-01

    3

    22

    4                   

    4                   

    2013-01-01

    4

    23

    5                   

    5                   

    2013-01-01

    5

    25

    7                   

    7                   

    2013-01-01

    7

    26

    8                   

    8                   

    2013-01-01

    8

    NULL

    NULL

    NULL

    NULL

    NULL

    针对上面的表,我使用存储过程对它做一些操作:

    1. 只返回单一记录集的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure GetUserAccountasselect * from UserAccountgo-------------执行上面的存储过程----------------exec GetUserAccount

     结果:相当于运行 select * from UserAccount 这行代码,结果为整个表的数据。

    2.没有输入输出的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure inUserAccountasinsert into UserAccount (UserName,[PassWord],RegisterTime,RegisterIP) values(9,9,'2013-01-02',9)go-------------执行上面的存储过程----------------exec inUserAccount

     结果:相当于运行 insert into UserAccount (UserName,[PassWord],RegisterTime,RegisterIP) values(9,9,'2013-01-02',9) 这行代码。

    3.有返回值的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure inUserAccountReasinsert into UserAccount (UserName,[PassWord],RegisterTime,RegisterIP) values(10,10,'2013-01-02',10)return @@rowcountgo-------------执行上面的存储过程----------------exec inUserAccountRe

     解释:这里的@@rowcount为执行存储过程影响的行数,执行的结果是不仅插入了一条数据,还返回了一个值即 return value =1  ,这个可以在程序中获取,稍后在c#调用存储过程中会有说到。

    4.有输入参数和输出参数的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure GetUserAccountRe@UserName nchar(20),@UserID int outputasif(@UserName>5)select @UserID=COUNT(*) from UserAccount where UserID>25elseset @UserID=1000go-------------执行上面的存储过程----------------exec GetUserAccountRe '7',null

     解释:@UserName为输入参数,@UserID为输出参数。 运行结果为@userIDCOOUT*)即 =1

    5. 同时具有返回值、输入参数、输出参数的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure GetUserAccountRe1@UserName nchar(20),@UserID int outputasif(@UserName>5)select @UserID=COUNT(*) from UserAccount where UserID>25elseset @UserID=1000return @@rowcountgo-------------执行上面的存储过程----------------exec GetUserAccountRe1 '7',null

     结果:@userIDCOOUT*)即 =1Retun Value=1

    6.同时返回参数和记录集的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure GetUserAccountRe2@UserName nchar(20),@UserID int outputasif(@UserName>5)select @UserID=COUNT(*) from UserAccount where UserID>25elseset @UserID=1000select * from UserAccountreturn @@rowcountgo-------------执行上面的存储过程----------------exec GetUserAccountRe2 '7',null

     结果:返回执行 select * from UserAccount 这句代码的结果集,同时@userIDCOOUT*)即 =1Retun Value=9 

    7.返回多个记录集的存储过程 

    -------------创建名为GetUserAccount的存储过程----------------create Procedure GetUserAccountRe3asselect * from UserAccountselect * from UserAccount where UserID>5go-------------执行上面的存储过程----------------exec GetUserAccountRe3

     结果:返回两个结果集,一个为 select * from UserAccount,另一个为 select * from UserAccount where UserID>5 

    小结:上面我们创建了各式的存储过程,下面看我们在c#中怎样调用这些存储过程。

     

  • 相关阅读:
    模拟出栈
    全排列 next_permutation 用法
    区间覆盖
    BFS GPLT L2-016 愿天下有情人都是失散多年的兄妹
    GPLT L2-014 列车调度
    图的联通分量个数统计(判断图是否联通)
    堆排序 GPLT L2-012 关于堆的判断
    牛客挑战赛 30 A 小G数数
    由树的中后序遍历求树的前层序遍历
    【HDOJ4699】Editor(对顶栈,模拟)
  • 原文地址:https://www.cnblogs.com/lizihong/p/4318316.html
Copyright © 2011-2022 走看看