SQL写存储过程时报错 'CREATE/ALTER PROCEDURE' must be the first statement in a query batch.

最近在学习存储过程,从网上直接复制了这个存储过程


if exists
(select name from sysobjects where name ='up_getallstudents' and type ='p')
drop procedure up_getallstudents
--编写存储过程up_getallstudents,用于获取学生表students的所有记录 
create procedure up_getallstudents 
as
select * from T_stu_cou


然后create procedure up_getallstudents 总报错,执行之后就提示

Msg 111, Level 15, State 1, Procedure up_getallstudents, Line 9
'CREATE/ALTER PROCEDURE' must be the first statement in a query batch.

然后找了一下原因,在create procedure up_getallstudents前缺少了GO,

因为这些语句需要放在单独的批处理中,在SQL Server中使用go来分批.

所以正确语句是

if exists
(select name from sysobjects where name ='up_getallstudents' and type ='p')
drop procedure up_getallstudents
--编写存储过程up_getallstudents,用于获取学生表students的所有记录 
GO
create procedure up_getallstudents 
as
select * from T_stu_cou

当然不是写一句就加GO,只要是在一个批处理就不用加GO,但是适当多加,显得清晰不容易出错,希望会帮到大家

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值