当前位置:首页 » 服务存储 » sql删除存储过程
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql删除存储过程

发布时间: 2022-01-29 08:56:22

❶ 怎样在sql server中创建,执行和删除存储过程

sqlserver存储过程的基本操作:

一、创建存储过程

1、语法格式:

createproc|procerepro_name
[{@参数数据类型}[=默认值][output],
{@参数数据类型}[=默认值][output],
....
]
as
SQL_statements

以上是最基本语法,举个简单的例子:

CREATEprocp_test
as
selectretu=1

存储过程返回一个结果集:1

2、执行存储过程

EXECUTEProcere_name''--存储过程如果有参数,后面加参数格式为:@参数名=value,也可直接为参数值value

例子调用结果:

dropprocereprocere_name--在存储过程中能调用另外一个存储过程,而不能删除另外一个存储过程

❷ plsql删除的存储过程

如果有开启归档日志的话,可以直接回滚;
另外如果是10g以上版本的话,可以使用flashback恢复,具体方法如下:
恢复存储过程的原理就是利用了oracle里所有的存储过程的源代码都是存在dba_source里,而drop某个存储过程的时候,oracle这里肯定要去dba_source里把相关的源代码给delete掉,既然是delete,那就可以直接flashback query了,如下:
SELECT *
FROM dba_source
AS OF TIMESTAMP TO_TIMESTAMP ('2015-03-30 00:00:00', 'YYYY-MM-DD HH24:MI:SS')
WHERE owner='' and name =''

❸ 怎样在Sql server中创建,执行和删除存储过程

存储过程是一类编译好的程序,在创建时进行编译,之后需要的时候值需要使用使用调用语句调用EXEC。

储存过程的分类:
1. 系统存储过程,存放在MASTER数据库中,以SP_前缀。
2. 用户自定义存储过程。

在SQL SERVER中创建储存过程语法:
Create proc[ere] procere_name[;number]
[{@parameter data_type}
[varying][=default][output]
][,…n]
[with {recompile|encryption|encrypton,recomption}]
[for enplication]
As
Sql_statement[,…n]
参数:
整个语法中只有两个参数是必须的:procere_name存储过程名称和sql_statement存储过程内容。
procere_name:存储过程名称。
;number:对存储过程分组,“;数字”表示是一组存储过程,便于批量操作。
@parameter:参数名,命名必须用@开头;局部变量以@开头,全局变量以@@开头。
data_type:参数类型。
varying:指定作为输出参数的结果集。
Default:参数的默认值。
Output:表示为输出参数,返回值给execute/exe。
[with {recompile|encryption|encrypton,recomption}][for enplication]:这个我还不明白。。。
As:指定储存过程要执行的操作。

执行存储过程语法:
Exec[ute] 存储过程名 参数

实验一下,看看效果:
1.创建一组存储过程并且执行
create procere procere_a;1
as
select * from student
go
create procere procere_a;2
as
select * from student
go
执行创建效果截图:

图1创建一组存储过程
2.执行语句:
Execute procere_a
效果截图:

图2执行存储过程效果截图
3.删除语句:
Drop procere procere_a
效果截图

图3删除一组储存过程效果截图

创建带输入参数的存储过程:输入参数是程序将参数值传递给存储过程。
创建一个带输入参数的存储过程,设置默认值,并且对输入参数的值进行判断。
Create procere pro_1
@pro_1_a varchar(20)=null
As
If @pro_1_a is null
Print'请输入需要查询的所属院系:'
else
Select avg(成绩) from student where 所属院系=@pro_1_a
分别执行一下:
1.exec pro_1
效果截图:

图4执行不带输入参数的语句
2.exec pro_1 ‘计算机’
效果截图:

图5执行带输入参数的语句
哈哈,verygood,有进步啊。

创建带输出参数的存储过程:输出参数是存储过程将返回值传递给程序。
1.输出函数需要指定output作为标识
2.声明变量需要使用declare
3.给变量指定值需要使用select
来一个例子:如果一个数大于5,则计算他的阶乘。
Create procere pro_2
/*声明输入输出参数*/
@in_x int,
@out_y int output
as
/*声明标量,并且赋值为1*/
Declare @x int,@y int
Select @x=1,@y=1
/*if语句判断输入值是否合法,使用while循环语句计算*/
If @in_x<=5
Print'请输入大于5的数:'
Else
While @x<=@in_x
Begin
Select @y=@y*@x
Select @x=@x+1
End
Select @out_y=@y
1.执行以上创建代码

图6创建带输入输出参数的存储过程截图
2.提供参数执行代码
Declare @out_sum int
Exec pro_2 6,@out_sum output
Select @out_sum as result

图7提供输入输出参数执行存储过程截图

创建多条语句的存储过程:一个存储过程中可以写入多条SQL语句,这些语句将被依次执行,可以实现多个功能。

删除存储过程delete及判断对象是否存在exists:
Delete procere procere_name
If exists(select子查询):如果exists的参数查询为非空,则exists结果为true,否则为假。
存储过程作为一个对象将被保存在数据库的sysobjects表中,可以使用语句判断这个对象是否存在:select * from sysobjects where name=’procere_name’

几个系统存储过程的使用:
Sp_name:重命名对象-- Sp_name object1,object2
Sp_depends:显示引用对象—sp_depends students
Sp_help:显示对象信息
Sp_helptext:显示对象的源代码

❹ SQL存储过程怎么写!!删除语句的

create proc 存储过程名
@id int

as

delete from 表名 where id=@id

GO

exec 存储过程名 1 --这样就调用存储过程从表中删除了ID记录为1的记录

❺ 怎样在Sql server中创建,执行和删除存储过程

  1. 创建存储过程:CREATE PROCEDURE 存储过程名 形参表 AS 存储过程体

  2. 执行存储过程:EXECUTE 存储过程名 实参表

  3. 删除存储过程:DROP PROCEDURE 存储过程名

存储过程(Stored Procere)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。

❻ SQL 如何删除指定数据库中的存储过程

可以通过drop语句进行实现。
sql:drop procere procerename;
解释:上面的sql语句的意思就是删除出存储过程名为procerename的存储过程。
备注:drop(删除)的通常是对象,如表(table)、视图(view),功能(function)等。

❼ 优化级联删除的存储过程SqlServer

这个感觉上, 加一个 DELETE CASCADE 方式 的外键约束, 就什么事情都解决了呀。


--创建测试主表.ID是主键.
CREATETABLEtest_main(
idINTNOTNULL,
valueVARCHAR(10),
PRIMARYKEY(id)
);


--创建测试子表.
CREATETABLEtest_sub(
idINTNOTNULL,
main_idINT,
valueVARCHAR(10),
PRIMARYKEY(id)
);


--插入测试主表数据.
INSERTINTOtest_main(id,value)VALUES(1,'ONE');
INSERTINTOtest_main(id,value)VALUES(2,'TWO');

--插入测试子表数据.
INSERTINTOtest_sub(id,main_id,value)VALUES(1,1,'ONEONE');
INSERTINTOtest_sub(id,main_id,value)VALUES(2,2,'TWOTWO');


1>--创建外键(使用ONDELETECASCADE选项,删除主表的时候,同时删除子表)
2>ALTERTABLEtest_sub
3>ADDCONSTRAINTmain_id_cons
4>FOREIGNKEY(main_id)REFERENCEStest_mainONDELETECASCADE;
5>
6>--测试删除主表数据.将成功地执行.
7>DELETE
8>TEST_MAIN
9>WHERE
10>ID=1;
11>
12>--测试检索子表,应该只有一条main_id=2的数据.
13>SELECT
14>*
15>FROM
16>test_sub;
17>
18>go

(1行受影响)
idmain_idvalue
--------------------------------
22TWOTWO

(1行受影响)

❽ 怎样在Sql server中创建,执行和删除存储过程

12345678910-- 创建存储过程create procere p_create_tableasbegin select getdate()end-- 执行存储过程exec p_create_table-- 删除存储过程drop procere p_create_table

❾ 怎样在Sql server中创建,执行和删除存储过程

创建:
Create
proc[ere]
procere_name[;number]
[{@parameter
data_type}
[varying][=default][output]
][,…n]
[with
{recompile|encryption|encrypton,recomption}]
[for
enplication]
As
Sql_statement[,…n]
参数:
整个语法中只有两个参数是必须的:procere_name存储过程名称和sql_statement存储过程内容。
procere_name:存储过程名称。
;number:对存储过程分组,“;数字”表示是一组存储过程,便于批量操作。
@parameter:参数名,命名必须用@开头;局部变量以@开头,全局变量以@@开头。
data_type:参数类型。
varying:指定作为输出参数的结果集。
Default:参数的默认值。
Output:表示为输出参数,返回值给execute/exe。
[with
{recompile|encryption|encrypton,recomption}][for
enplication]:这个我还不明白。。。
As:指定储存过程要执行的操作。
执行:
exec
test_sp
删除:
drop
proc
test_sp