SQL server存储过程学习
由于之前使用 Linq to Sql来操作数据库,对于数据库的存储过程、函数等比较薄弱。乘着自己闲着的时候,就百度自学了一点存储过程,以防以后要用。
基础通俗易懂的存储过程通过 存储过程学习 ,然后自己写了几个基础的存储过程方便自己了解他的语法。
ALTER PROCEDURE [dbo].[pro_study]
@name varchar(50)='huage', --输入参数//全局变量声明
@result varchar(10) OUTPUT --输出参数
AS
BEGIN
if(select COUNT(1) from t_student where Name=@name)>0
SET @result='存在'
ELSE
set @result='不存在'
END --这边是调用存储过程
--定义变量声明@result 然后输出
DECLARE @result varchar(10)
exec test_study 'hauge',@result output
PRINT @result--这边是直接给参数返回,不建议使用
对于这边的全局变量的输出,C#的调用方法如下:
public static string DBExecutepParmOutput(CommandType cType, string cText)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
SqlCommand cmd = conn.CreateCommand();
cmd.CommandType = cType;
cmd.CommandText = cText;
SqlParameter[] parms ={
new SqlParameter("@name","huage"),
new SqlParameter("@result",SqlDbType.VarChar,)
};
parms[].Direction = ParameterDirection.Output;
cmd.Parameters.AddRange(parms);
conn.Open();
cmd.ExecuteScalar();
return parms[].Value + "";
}
}
这边是通过全局变量的传入,输出所需的结果集
ALTER PROCEDURE [dbo].[pro_study1]
@id int
AS
BEGIN
declare @result VARCHAR(20)
if(select COunt(1) from t_student where Id=@id)>0
set @result='存在'
ELSE set @result='不存在' SELECT @result
END
对于这边的局部变量(select)的输出,C#的调用方法如下:
public static string DBExecuteScalar(CommandType cType, string cText, SqlParameter[] parms)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
SqlCommand cmd = conn.CreateCommand();
cmd.CommandType = cType;
cmd.CommandText = cText;
cmd.Parameters.AddRange(parms);
conn.Open();
var res = cmd.ExecuteScalar() + "";
return res;
}
}
下面是定义局部变量,并且赋值查询表,返回结果集合(C#调用就比较简单_就不展示了)
ALTER PROCEDURE [dbo].[pro_study2]
@id varchar(50)--//全局变量
AS --//as 前面的是全局变量,后面的是局部变量
DECLARE @name varchar(50) --//局部变量
set @name='huage'
BEGIN
set @id=1
select * from t_student where Name=@name
select * from t_student where Id=@id
END
下面是输出数据库里面内置函数的结果集:
ALTER PROCEDURE [dbo].[pro_rowcount]
AS
BEGIN
INSERT into t_student VALUES ('huage','','男神'),
('wudi','','女神') --begin...end 类似编程语言中的{} select @@rowcount --返回影响的行数
select @@identity --返回最近插入的标识列的Id
END
下面是使用游标循环数据库表的基本语法
ALTER PROCEDURE [dbo].[pro_youbiao]
AS
BEGIN
DECLARE @temp int,--定义的游标的变量
@error INT --记录错误
DECLARE m_cursor CURSOR FOR (select Id from t_student)--定义游标
OPEN m_cursor --打开游标
--开始循环游标变量--
FETCH NEXT FROM m_cursor into @temp
WHILE @@FETCH_Status=0 --返回被 FETCH语句执行的最后游标的状态--
--这边是对数据的操作
BEGIN--beging end 相当于C#中的{}
UPDATE t_student SET test=CONVERT(VARCHAR(10),@temp) where Id=@temp
set @error=@error+@@ERROR -- --记录每次运行sql后是否正确,0正确
FETCH next FROM m_cursor into @temp --转到下一个游标,没有会死循环
END
close m_cursor --关闭游标
deallocate m_cursor --释放游标 SELECT @error
END
SQL server存储过程学习的更多相关文章
- SQL server 存储过程学习
一.定义变量--简单赋值 declare @a intset @a=5 print @a --使用select语句赋值 declare @user1 nvarchar(50) select @user ...
- 关于SQL SERVER数据库学习总结
对于SQL SERFVER数据库也学了有一阵子了,自己也对自己所学做了一些总结. 我们首先学习数据库设计的一些知识点和用SQL语句建库. 设计数据库步骤:需求分析阶段,概要设计阶段,详细设计阶段, 建 ...
- SQL Server存储过程中使用表值作为输入参数示例
这篇文章主要介绍了SQL Server存储过程中使用表值作为输入参数示例,使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据,这样 ...
- SQL Server存储过程Return、output参数及使用技巧
SQL Server目前正日益成为WindowNT操作系统上面最为重要的一种数据库管理系统,随着 SQL Server2000的推出,微软的这种数据库服务系统真正地实现了在WindowsNT/2000 ...
- SQL Server 存储过程(转载)
SQL Server 存储过程 Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用.当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句.这 ...
- SQL SERVER XML 学习总结
SQL SERVER XML 学习总结 最新的项目任务要做一个数据同步的功能,这些天都在做技术准备,主要是用到了微软的Service Broker技术,在熟悉使用该技术的同时,又用到了Sql s ...
- 14、SQL Server 存储过程
SQL Server 存储过程 存储过程类似函数,可以重复使用.相对于函数,存储过程拥有更强大的功能和更高的灵活性. 存储过程中可以包含逻辑控制语句和数据操作语句,可以接受参数,输出参数,返回单个值或 ...
- (摘录)SQL Server 存储过程
文章摘录:http://www.cnblogs.com/hoojo/archive/2011/07/19/2110862.html SQL Server 存储过程 Transact-SQL中的存储过程 ...
- Sql Server 存储过程中查询数据无法使用 Union(All)
原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...
随机推荐
- 【技术累积】【点】【编程】【13】XX式编程
(原)函数式编程 核心概念 函数式一等公民(输入输出啥的都可以是函数): 纯函数,固定输入带来固定输出: 阅读性良好,无并发问题,但效率偏低: 大历史背景 旨在描述问题如何计算: 有两位巨擘对问题的可 ...
- react基础篇二
组件 & Props & 生命周期 组件可以将UI切分成一些独立的.可复用的部件,这样你就只需专注于构建每一个单独的部件. 组件从概念上看就像是函数,它可以接收任意的输入值(称之为“p ...
- sqlserver where in 在 mysql
) tmp); 主句(select * from (从句 temp) sql的 where in 删除 要更改为 // in( select * from ((select idfrom twhe ...
- vue遇到的大坑,h5在ios10版本下不能打开页面
无论是谁,在做事情的过程中总是会遇到学坑,才能成为最后的大神 这个坑不说了,找了半天.希望能帮助到你们 进入build文件夹: 找到webpack.prod.conf.js文件: 在UglifyPlu ...
- ListUtil集合操作常用方法类
* 集合操作常用方法类. * <p> * * @author 柯 */ public class ListUtil { /** * 判断List不为空,非空返回true,空则返回false ...
- php第七节课
多态,重载,克隆 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...
- 关于node对文件的读取
设计: 通过终端git / cmd 获取用户输入路径,然后遍历路径下所有的文件,打印输出. 因为需要命令行交互,所以引入prompt库 (https://github.com/flatiron/pro ...
- javascript/jquery获取地址栏url参数的方法
1.jquery获取url window.location.href; 2.通过javascript是如何获取url中的某个参数 function getUrlParam(name) { var re ...
- 《奋斗吧!菜鸟》 第八次作业:Alpha冲刺 Scrum meeting 1
项目 内容 这个作业属于哪个课程 任课教师链接 作业要求 https://www.cnblogs.com/nwnu-daizh/p/11012922.html 团队名称 奋斗吧!菜鸟 作业学习目标 A ...
- 图论·Floyd算法·HDU2544&1874 (伪)2066
在看到1874的题时,第一反应是用上一篇的并查集方法,后来查了一下是要用Floyd做,所以就去查Floyd算法的资料. 即插点法,是一种用于寻找给定的加权图中顶点间最短路径的算法. 核心代码: ma ...