在SQL中存储过程的一般语法
一般分为十种情况,每种语法各不相同:
1、 创建语法
1
2
3
4
5
6
7
|
create proc | procedure pro_name [{@参数数据类型} [=默认值] [ output ], {@参数数据类型} [=默认值] [ output ], .... ] as SQL_statements |
2、 创建不带参数存储过程
1
2
3
4
5
6
7
8
9
10
|
--创建存储过程 if (exists ( select * from sys.objects where name = 'proc_get_student' )) drop proc proc_get_student go create proc proc_get_student as select * from student; --调用、执行存储过程 exec proc_get_student; |
3、 修改存储过程
1
2
3
4
|
--修改存储过程 alter proc proc_get_student as select * from student; |
4、 带参存储过程
1
2
3
4
5
6
7
8
9
10
|
--带参存储过程 if (object_id( 'proc_find_stu' , 'P' ) is not null ) drop proc proc_find_stu go create proc proc_find_stu(@startId int , @endId int ) as select * from student where id between @startId and @endId go exec proc_find_stu 2, 4; |
5、 带通配符参数存储过程
1
2
3
4
5
6
7
8
9
10
11
|
--带通配符参数存储过程 if (object_id( 'proc_findStudentByName' , 'P' ) is not null ) drop proc proc_findStudentByName go create proc proc_findStudentByName(@ name varchar (20) = '%j%' , @nextName varchar (20) = '%' ) as select * from student where name like @ name and name like @nextName; go exec proc_findStudentByName; exec proc_findStudentByName '%o%' , 't%' ; |
6、 带输出参数存储过程
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
if (object_id( 'proc_getStudentRecord' , 'P' ) is not null ) drop proc proc_getStudentRecord go create proc proc_getStudentRecord( @id int , --默认输入参数 @ name varchar (20) out , --输出参数 @age varchar (20) output --输入输出参数 ) as select @ name = name , @age = age from student where id = @id and sex = @age; go -- declare @id int , @ name varchar (20), @ temp varchar (20); set @id = 7; set @ temp = 1; exec proc_getStudentRecord @id, @ name out , @ temp output ; select @ name , @ temp ; print @ name + '#' + @ temp ; |
7、 不缓存存储过程
1
2
3
4
5
6
7
8
9
10
11
|
--WITH RECOMPILE 不缓存 if (object_id( 'proc_temp' , 'P' ) is not null ) drop proc proc_temp go create proc proc_temp with recompile as select * from student; go exec proc_temp; |
8、 加密存储过程
1
2
3
4
5
6
7
8
9
10
11
12
13
|
--加密WITH ENCRYPTION if (object_id( 'proc_temp_encryption' , 'P' ) is not null ) drop proc proc_temp_encryption go create proc proc_temp_encryption with encryption as select * from student; go exec proc_temp_encryption; exec <a href= "https://www.baidu.com/s?wd=sp_helptext&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1YYm103n1DYmHfknhD3nWD10ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EPW63nHcdrH6" target= "_blank" class= "baidu-highlight" >sp_helptext</a> 'proc_temp' ; exec <a href= "https://www.baidu.com/s?wd=sp_helptext&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1YYm103n1DYmHfknhD3nWD10ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EPW63nHcdrH6" target= "_blank" class= "baidu-highlight" >sp_helptext</a> 'proc_temp_encryption' ; |
9、 带游标参数存储过程
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
if (object_id( 'proc_cursor' , 'P' ) is not null ) drop proc proc_cursor go create proc proc_cursor @cur cursor varying output as set @cur = cursor forward_only static for select id, name , age from student; open @cur; go --调用 declare @exec_cur cursor ; declare @id int , @ name varchar (20), @age int ; exec proc_cursor @cur = @exec_cur output ; --调用存储过程 fetch next from @exec_cur into @id, @ name , @age; while (<a href= "https://www.baidu.com/s?wd=%40%40fetch_status&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1YYm103n1DYmHfknhD3nWD10ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EPW63nHcdrH6" target= "_blank" class= "baidu-highlight" >@@fetch_status</a> = 0) begin fetch next from @exec_cur into @id, @ name , @age; print 'id: ' + convert ( varchar , @id) + ', name: ' + @ name + ', age: ' + convert ( char , @age); end close @exec_cur; deallocate @exec_cur; --删除游标 |
10、 分页存储过程
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
---存储过程、row_number完成分页 if (object_id( 'pro_page' , 'P' ) is not null ) drop proc proc_cursor go create proc pro_page @startIndex int , @endIndex int as select count (*) from product ; select * from ( select row_number() over( order by pid) as rowId, * from product ) temp where temp .rowId between @startIndex and @endIndex go --drop proc pro_page exec pro_page 1, 4 -- --分页存储过程 if (object_id( 'pro_page' , 'P' ) is not null ) drop proc pro_stu go create procedure pro_stu( @pageIndex int , @pageSize int ) as declare @startRow int , @endRow int set @startRow = (@pageIndex - 1) * @pageSize +1 set @endRow = @startRow + @pageSize -1 select * from ( select *, row_number() over ( order by id asc ) as number from student ) t where t.number between @startRow and @endRow; exec pro_stu 2, 2; |
在SQL中存储过程的一般语法的更多相关文章
- SQL中存储过程和函数的区别
转:https://www.cnblogs.com/jacketlin/p/7874009.html 本质上没区别.只是函数有如:只能返回一个变量的限制.而存储过程可以返回多个. 而函数是可以嵌入在s ...
- 面试问题 - SQL 中存储过程与函数的区别
SQL 中的存储过程与函数没有本质上的区别 函数 -> 只能返回一个变量. 函数可以嵌入到sql中使用, 可以在select 中调用, 而存储过程不行. 但函数也有着更多的限制,比如不能使用临 ...
- Sql 中存储过程详细案例
转自:http://www.cnblogs.com/yank/p/4235609.html 概念 存储过程(Stored Procedure):已预编译为一个可执行过程的一个或多个SQL语句. 创建存 ...
- SQL中存储过程和自定义函数的区别
存储过程: 存储过程可以使得对数据库的管理.以及显示关于数据库及其用户信息的工作容易得多.存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理.存储过程存储在 ...
- SQL中存储过程的例子
导读:sql存储是数据库操作过程中比较重要的一个环节,对于一些初学者来说也是比较抽象难理解的,本文我将通过几个实例来解析数据库中的sql存储过程,这样就将抽象的事物形象化,比较容易理解. 例1: cr ...
- SQL中存储过程中使用事务,并且加入异常处理机制.
--存储过程中使用事务,并且加入异常处理机制. -- ============================================= CREATE PROCEDURE [dbo].[UP_ ...
- SQL中存储过程和自定义函数的区别(转载)
存储过程: 存储过程可以使得对数据库的管理.以及显示关于数据库及其用户信息的工作容易得多.存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理.存储过程存储在 ...
- SQL中Like语句的语法
在SQL结构化查询语言中,LIKE语句有着至关重要的作用. LIKE语句的语法格式是:select * from 表名 where 字段名 like 对应值(子串),它主要是针对字符型字段的,它的作用 ...
- 在Delphi中如何获得SQL中存储过程的返回值?
示例存储过程:create procedure proc_loginusername varchar(20),password varchar(20)asdeclare @result intsele ...
随机推荐
- Codeforces Round #303 (Div. 2) E. Paths and Trees Dijkstra堆优化+贪心(!!!)
E. Paths and Trees time limit per test 3 seconds memory limit per test 256 megabytes input standard ...
- Mac 找文件或文件夹,以及开启其他程序,截图快捷键
Mac 图形化界面对操作惯 Win 的人来说比较奇怪. 有一组超级有用的快捷键,control + 空格 按下后会出现一个搜索框,输入计算机上任何你想要找的资源即可打开. 截取全屏:快捷键(Shift ...
- maven 高级玩法
maven 高级玩法 标签(空格分隔): maven 实用技巧 Maven 提速 多线程 # 用 4 个线程构建,以及根据 CPU 核数每个核分配 1 个线程进行构建 $ mvn -T 4 clean ...
- lianjie3
http://7xj7xs.com1.z0.glb.clouddn.com/xiao-chengxu.mp4
- React Native商城项目实战03 - 包装Navigator
1.在Home目录下新建首页详细页HomeDetail.js /** * 首页详情页 */ import React, { Component } from 'react'; import { App ...
- JS获取select被选中的option的值
一:JavaScript原生的方法 1:拿到select对象: var myselect=document.getElementById(“test”); 2:拿到选中项的索引:var index=m ...
- ssh config高级用法
转载自:Chapter 7. Advanced Client Use 1. 配置文件 ssh1和Openssh的配置文件在.ssh/ssh_config ssh2配置文件在.ssh2/ssh2_con ...
- Unity ZTest 深度测试 & ZWrite 深度写入
初学Shader,一开始对于渲染队列,ZTest 和 ZWrite一头雾水,经过多方查阅和实验,有了一些自己的理解.发此文与初学Shader的朋友分享,也算是为自己做个笔记.不对或不足之处欢迎指正. ...
- oracle ogg 单实例双向复制搭建(oracle-oracle)--Oracle GoldenGate
oracle ogg 单实例双向复制搭建(oracle-oracle)--Oracle GoldenGate --继昨天的测试,这一篇实施单实例双向复制(完全重新搭建) --环境不变 db1,db2( ...
- Go语言入门篇-使用Beego构建完整web应用
使用Beego构建完整web应用 一.GO简介(Beego应用go编写) 1.为什么用GO (1).语法简单 (2).简洁的并发 (3).开发和执行效率快(编译型语言) 2.GO语言环境 下载go & ...