SQLSERVER存储过程基础
SQLSERVER存储过程基础
1.声明变量
DECLARE @F001 SMALLINT, (三元素,声明declare+变量名+类型)
@F002 INTEGER,
@F003 VARCHAR(20),
@F004 CHAR(20),
@@F002 MONEY
2.赋值语句
SET @F001 =space(40) @F002= 3
3.条件判断(IF...ELSE)
IF condition BEGIN
[statements ]
END
ELSE BEGIN (ELSE IF condition2 BEGIN)
[elseifstatements ]
END
4.多分支判断(case[when...then...else...] end)
SET @F011 =
CASE
WHEN [testexpression1] THEN @F001
WHEN [testexpression2] THEN @F002
WHEN [testexpression3] THEN @F003
WHEN [testexpression4] THEN @F004
END
5.循环(while)
WHILE condition BEGIN
[statements ]
END
6.动态定义游标(*)
DECLARE @strSQL nvarchar(30)
DECLARE @inSQL nvarchar(50) -- select...
SET @strSQL = ' DECLARE name_cursor CURSOR FOR
' + @inSQL
EXEC (@strSQL)
7.遍历游标
FETCH NEXT FROM name_cursor into@F001,@F002 (要求与游标的返回值对应)
WHILE @@FETCH_STATUS = 0 BEGIN (如@inSQL是selectf001,f002 from tablename)
FETCH NEXT FROM name_cursor into @F001,@F002
END (说明:FETCH_STATUS检索到数据返回0,失败返回-1,可判断是否滚动未到结尾。)
8.获得游标行数
SET @RECCNT = @@ROWCOUNT --内嵌参数@@FETCH_STATUS
同
9.事务处理
BEGIN distributed transaction
WHILE @@TRANCOUNT > 0
commit transaction
10.字符串连接
SET @m_sql = @m_sql + ' Where F001 = ''' +@F001 + ''''
SET @m_sql = @m_sql + ' F002 = ' + CONVERT(varchar,@F002) convert会加引号?
11.存储过程的调用及返回值
(1)存储过程的创建 (sql server数据库中create procedure)
CREATE PROCEDURE material_solo_days_proc
(@materialnovarchar(20),
@year_month datetime,
@totalday int,
@qty decimal(18,4)=0 output
--总量,也会return
)
AS
BEGIN
DECLARE@@count
int
SET@@count = 0
DECLARE@@dailyqty
decimal(18,4)
SET@@dailyqty
= 0
SET@qty = 0
WHILE@@count < @totalday
BEGIN
--计算日流水量
EXECUTE @@dailyqty
= material_solo_oneday_proc @materialno,@year_month
SET @qty
= @qty + @@dailyqty
SET @year_month
= dateadd(dd,1,@year_month)
SET @@count
= @@count + 1
END
RETURN@qty
END
(2)SQL-DELPHI调用存储过程(open/execproc)
withmaterial_account_proc do
begin
Close;
ProcedureName:='material_account_proc';
Parameters.Clear;
Parameters.Refresh;
Parameters.ParamByName('@year_month').Value:= year_month;
Parameters.ParamByName('@condition').Value:= ''; //string不匹配nvarchar
open;
y :=Parameters.ParamByName('@count').Value;
x := Parameters.ParamByName('@totalday').Value;
end;
(3)存储过程调用存储过程
DECLARE @C001 VARCHAR(20),
@C002 SMALLINT
EXEC name_produce @C001,@C002 output
/////////////////////////////////////////////////////////////////////////////////
12.动态sql语句的创建和执行()
CREATE PROCEDURE usp_GetSalesHistory
(
@WhereClauseNVARCHAR(2000)=NULL
)
AS
BEGIN
DECLARE @SelectStatement NVARCHAR(2000)
DECLARE @FullStatement NVARCHAR(4000)
SET @SelectStatement = 'SELECT * FROM SalesHistory'
SET @FullStatement = @SelectStatement +ISNULL(@WhereClause,' ')
PRINT @FullStatement
EXECUTE sp_executesql @FullStatement
/*EXECUTE(@FullStatement) */
END
说明: sp_executesql
执行的不能是varchar只能是nvarchar,sp_executesql
支持独立于 Transact-SQL
字符串设置参数值,有更多例子网上搜。
Execute可以是varchar,而且execute的sql语句中的参数只能是属性列或者表
13.Update语句常见错误总结 (update .,.set where)
--√
Update name_table set
F001 = @F181,
F002 = @F182
Where
F003 = @F003
--×
Update name_table
F001 = @F181,
F002 = @F182
Where
F003 = @F003
--×
Update name_table set
F001 = @F181,
F002 = @F182,
Where
F003 = @F003
--×
Update name_table set
,F001 = @F181
,F002 = @F182
Where
F003 = @F003
14.Insert语句常见语法错误总结
--√
INSERT INTO name_table(
,KEY_FIELD,BUSYOCD
)Values(
@F001,@F002
)
--×
INSERT INTO name_table(
F001,F002
)Values(
,@F001,@F002
)
--×
INSERT INTO name_table(
F001,F002
)Values(
@F001,@F002,
)
--×
INSERT name_table(
F001,F002
)Values(
@F001,@F002
)
SQLSERVER存储过程基础的更多相关文章
- 解剖SQLSERVER 第十五篇 SQLSERVER存储过程的源文本存放在哪里?(译)
解剖SQLSERVER 第十五篇 SQLSERVER存储过程的源文本存放在哪里?(译) http://improve.dk/where-does-sql-server-store-the-sourc ...
- Sqlserver 存储过程中结合事务的代码
Sqlserver 存储过程中结合事务的代码 --方式一 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[ ...
- SqlServer存储过程学习笔记(增删改查)
* IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值. CREATE PROCEDURE [dbo].[PR_NewsAffiche_AddNewsEntity] ( ...
- SQLServer 存储过程嵌套事务处理
原文:SQLServer 存储过程嵌套事务处理 某个存储过程可能被单独调用,也可能由其他存储过程嵌套调用,则可能会发生嵌套事务的情形. 下面是一种解决存储过程嵌套调用的通用代码,在不能确定存储过程是否 ...
- 创建并在项目中调用SQLSERVER存储过程的简单示例
使用SQLSERVER存储过程可以很大的提高程序运行速度,简化编程维护难度,现已得到广泛应用.创建存储过程 和数据表一样,在使用之前需要创建存储过程,它的简明语法是: 引用: Create PROC ...
- SQLSERVER存储过程语法详解
CREATE PROC [ EDURE ] procedure_name [ ; number ] [ { @parameter data_type } [ VARYING ] [ = default ...
- SqlServer存储过程详解
SqlServer存储过程详解 1.创建存储过程的基本语法模板: if (exists (select * from sys.objects where name = 'pro_name')) dro ...
- sqlServer存储过程与sql语句的区别
sqlServer 存储过程与sql语句的区别 sql存储过程与sql语句的区别: 从以下几个方面考虑: 1.编写: 存储过程:编写比较难: sql语句:相对简单: 2.性能: 存储过程:高,可移 ...
- SqlServer存储过程(增删改查)
* IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值. CREATE PROCEDURE [dbo].[PR_NewsAffiche_AddNewsEntity] ( ...
随机推荐
- Python爬虫学习——1.爬虫入门
HTTP和HTTPS HTTP协议(HyperText Transfer Protocol,超文本传输协议):是一种发布和接收 HTML页面的方法. HTTPS(Hypertext Transfer ...
- 【前端 · 面试 】HTTP 总结(十二)—— URL 和 URI
最近我在做前端面试题总结系列,感兴趣的朋友可以添加关注,欢迎指正.交流. 争取每个知识点能够多总结一些,至少要做到在面试时,针对每个知识点都可以侃起来,不至于哑火. 引言 不知道有多少人是和我一样分不 ...
- Spring Cloud Alibaba - Spring Cloud Stream 整合 RocketMQ
Spring Cloud Stream 简介 在微服务的开发过程中,可能会经常用到消息中间件,通过消息中间件在服务与服务之间传递消息,不管你使用的是哪款消息中间件,比如RabbitMQ.Kafka和R ...
- 用华为云cli,管理华为云服务器的,安全组端口
---[前言]--- 关键字 hcloud 华为 命令行 linux windows powershell 前些天,大家因为华为云,是否应该默认开启端口,大家吵起来了,所以我抽空写了此文.解决问题,缓 ...
- Linux的磁盘管理和文件系统
一.磁盘结构 1.1.硬盘的物理结构 盘头:硬盘有多个盘片,每盘片2面 磁头:每面一个磁头 1.2.硬盘的数据结构 扇区:盘片被分为多个扇形区域,每个扇区存放512字节的数据,硬盘的最小存储单位 磁道 ...
- 使用POI把查询到的数据表数据导出到Excel中,一个表一个sheet.最详细!!!
一.需求 我们会遇到开发任务: 经理:小王,你来做一下把数据库里的数据导出到Excel中,一个表是一个sheet,不要一个表一个Excel. 小王:好的,经理.(内心一脸懵逼) 二.前期准备 首先我们 ...
- XSS之防御与绕过
很久之前的随笔讲过XSS的编码绕过的一些内容 本次侧重整理一下常见的防御思路,顺便补充一些针对性的绕过思路以及关于XSS个人想到的一些有趣的事情 开篇之前,先看一下XSS介绍(包括mXSS.uXSS. ...
- 003 TCP/IP协议详解(二)
一.ping ping可以说是ICMP的最著名的应用,是TCP/IP协议的一部分.利用"ping"命令可以检查网络是否连通,可以很好地帮助我们分析和判定网络故障. 例如:当我们某一 ...
- luoguP1528&2329 栅栏&切蛋糕
前言 蒟弱本来是在亿万年前做二分答案专题栅栏的,由于数据水所以过掉了,后来发现有一个数据加强版,也就是本题,于是爆T了...过了有个五六个月回来填坑了...现在开O2是在最优解第一个(自豪ing 题目 ...
- Linux的wget命令详解
[转载] Linux wget是一个下载文件的工具,它用在命令行下.对于Linux用户是必不可少的工具,尤其对于网络管理员,经常要下载一些软件或从远程服务器恢复备份到本地服务器.如果我们使用虚拟主机, ...